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前 言 


PHP 是 当今 全 球 最 普及 、 应 用 最 广泛 的 Web 应 用 开发 语言 之 一 ， 全 世界 有 超过 3000 
万 个 网 站 和 2 万 多 家 公司 选用 了 PHP， 其 中 包括 百度 、 雅 虎 、 德 国 汉莎 航空 电子 售票 系 
统 、 华 尔 街 在 线 的 金融 信息 发 布 系统 等 。 在 近 几 年 的 编程 语言 排行 榜 中 ，PHP 以 其 卓越 的 
性 能 一 直 稳 居 前 茅 ，PHP 7.0 的 正式 发 布 更 是 掀起 了 新 一 轮 的 PHP 应 用 狂潮 。 

作者 根据 多 年 的 教学 经 验 ， 结 合 最 新 发 布 的 PHP 7.0 和 MySQL 数据 库 ， 在 分 析 、 总 
结 国内 外 多 种 同类 教材 的 基础 上 ， 编 写 了 本 书 。 本 书 力求 理论 联系 实际 ， 通 过 贯穿 全 书 的 
实 训 案例 ， 引 导 和 启发 学 生 快 速 掌握 网 站 建设 的 方法 。 

本 书 共 分 14 章 ， 内 容 如 下 。 

第 1 章 主要 介绍 PHP 语言 的 发 展 过 程 及 特点 、XAMPP 系统 的 安装 与 启动 、PHP 语言 
的 基本 语法 知识 。 

第 2 章 主要 介绍 PHP 语言 的 数据 类 型 、 常 量 和 变量 、 运 算 符 和 表达 式 等 内 容 。 

第 3 章 主 要 介绍 PHP 流程 控制 语句 一 一 if 语句 、f...else 语句 、switch 语句 、while 语 
句 、for 语句 等 内 容 。 

第 4 章 主要 介绍 自 定义 函数 的 基本 概念 、 变 量 的 作用 域 等 内 容 。 

第 5 章 主 要 介绍 数组 概述 、 一 维 数组 、 二 维 数组 等 内 容 。 

第 6 章 主 要 介绍 字符 串 基 本 概念 、 处 理 字符 串 的 相关 函数 等 内 容 。 

第 7 章 主 要 介绍 Web 页 面 各 类 控件 的 属性 以 及 PHP 程序 采集 数据 的 方法 等 内 容 。 

第 8 章 主要 介绍 MySQL 数据 库 以 及 操作 数据 库 、 数 据 表 、 记 录 等 相关 SQL 语句 和 
MySQL 命令 等 内 容 。 

第 9 章 主 要 介绍 PHP 程序 连接 MySQL 数据 库 ， 利 用 SQL 语句 操作 数据 表 、 记 录 等 





内 容 。 
第 10 章 主要 介绍 PHP 中 Cookie 和 Session 的 基本 概念 及 应 用 方法 等 内 容 。 

第 11 章 主要 介绍 PHP 中 图 形 图 像 的 处 理 方 法 等 内 容 。 

第 12 章 主要 介绍 PHP 中 文件 和 目录 的 操作 方法 等 内 容 。 

第 13 章 主要 介绍 PHP 中 面向 对 象 的 基本 概念 和 类 的 相关 应 用 等 内 容 。 

第 14 章 主要 介绍 利用 PDO 数据 库 抽 象 层 连接 MySQL 数据 库 ， 操 作 MySQL 数据 
表 、 记 录 等 内 容 。 

本 书 内 容 丰 富 、 结 构 合 理 、 思 路 清晰 、 语 言 简练 流畅 ， 书 中 所 有 实例 都 已 在 XAMPP 
系统 下 调试 并 运行 通过 。 为 了 能 让 读者 更 好 地 掌握 PHP 和 MySQL， 大 部 分 章节 都 编写 了 
一 个 综合 实 训 案 例 。 读 者 依据 本 书 循序 渐进 地 学 习 ， 可 以 巩固 基本 知识 ， 培 养 实践 能 力 ， 
增强 对 基本 概念 的 理解 和 解决 实际 问题 的 能 力 ， 能 够 高 效 地 掌握 PHP 开发 网 站 的 技巧 。 

本 书 获 内 蒙古 科技 大 学 教材 建设 项 目 资助 ， 主 要 由 内 蒙古 科技 大 学 计算 机 教学 基地 的 
教师 编写 ， 由 黄 迎 久 ( 内 蒙古 科技 大 学 计算 机 教学 基地 ) 和 石 炜 (内 蒙古 科技 大 学 机 械 工程 学 
院 ) 任 主编 ， 内 蒙古 科技 大 学 计算 机 教学 基地 的 赵 军 富 、 徐 扬 、 张 利 新 、 王 猛 任 副 主 编 。 本 
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书写 作 分 工 : 第 1 章 、 第 9 章 和 第 12 章 由 徐 扬 编 写 ， 第 2 章 和 第 6 章 由 张 利 新 编写 ， 第 3 
章 和 第 11 章 由 王猛 编写 ， 第 8 章 和 第 14 章 由 赵 军 富 编写 ， 第 4 章 、 第 $ 章 和 第 7 章 由 石 
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由 于 作者 水 平 有 限 ， 书 中 的 朴 漏 和 不 妥 在 所 难免 ， 欢 迎 广大 读者 批评 指正 。 如 果 您 对 
本 书 有 什么 建议 和 意见 ， 欢 迎 发 邮件 至 hyingjiu@163.com。 
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本 章 要 点 

@ PHP 的 语法 特点 

@ ”PHP 的 标记 、 注 释 

@ PHP 开发 工具 的 应 用 

学 习 目 标 

@ 掌握 PHP 的 基本 语法 知识 
@ 掌握 PHP 开发 工具 的 应 用 


1.1 PHP 简介 
1.1.1 PHP 概述 


PHP 最 初 是 Personal Home Page 的 缩写 ， 后 正式 更 名 为 Hypertext Preprocessor( 超 文本 
预 处 理 器 )。 它 是 一 种 通用 开源 脚本 语言 ， 语 法 上 吸收 了 C、Java 和 Perl 语言 的 特点 ， 利 于 
学 习 ， 应 用 广泛 ， 主 要 适用 于 Web 开发 领域 。PHP 是 将 程序 嵌入 HTML(Hyper Text 
Markup Language， 超 文本 标记 语言 ) 文 档 中 去 执行 ， 用 PHP 写 出 的 动态 页 面 ， 其 执行 效率 
极其 高 效 。PHP 能 够 运行 在 包括 Windows、Linux 等 在 内 的 大 多 数 操作 系统 环境 中 ， 常 与 
免费 的 Web 服务 器 软件 Apache 和 免费 的 数据 库 MySQL 配合 使 用 ， 号 称 “ 黄 金 组 合 ”。 


1. PHP 的 发 展 过 程 


PHP 是 由 Rasmus Lerdorf 于 1994 年 开发 的 ， 最 初 是 用 来 统计 网 站 的 访问 者 ， 后 来 加 
入 了 访问 数据 库 的 功能 。1995 年 正式 发 布 了 PHP 1.0， 同 年 在 增加 了 循环 语句 、 数 组 变量 
等 新 特性 后 发 布 了 PHP 2.0; 1997 年 推出 PHP 3.0， 此 时 使 用 PHP 的 网 站 已 超过 5 万 个 ; 
2000 年 PHP 4.0( 简 称 PHP4) 问 世 ，PHP4 的 内 核 已 大 幅 优化 更 新 ， 拥 有 更 强 的 新 功能 、 更 
丰富 的 函数 库 ，PHP 程序 的 执行 速度 更 加 快速 ， 此 时 PHP 在 Web 开发 领域 掀起 了 颠覆 性 
的 革命 。2004 年 又 推出 了 PHP5， 标 志 着 一 个 全 新 的 PHP 时 代 的 到 来 。PHP5 的 最 大 特点 
是 引入 了 面向 对 象 的 全 部 机 制 ， 并 且 保 留 了 向 下 的 兼容 性 。 其 功能 更 加 完善 ， 兼 容 性 更 
强 ， 稳 定性 上 更 胜 一 筹 。2015 年 12 月 ，PHP 7.0 正式 发 布 ， 据 检测 ，PHP 7.0 的 性 能 比 
PHP5 提高 了 2 倍 ， 其 优异 的 特性 和 功能 还 是 非常 具有 发 展 前 景 和 吸引 力 的 (本 书 主要 以 
PHP 7.0 进行 讲解 )。 

2. PHP 的 特点 


(1) 速度 快 。 

PHP 是 一 种 强大 的 Web 开发 脚本 语言 ， 执 行 网 页 的 速度 比 CGI、Perl 和 ASP 更 快 。 

(2) 易 掌 握 。 

PHP 语言 的 风格 类 似 于 C 语言 ， 非 常 易于 学 习 ， 只 需要 了 解 一 些 PHP 的 语法 知识 ， 
就 可 以 开始 PHP 编程 之 旅 。 
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(3) 功能 强大 。 


可 以 支持 目前 流行 的 绝 大 多 数 数据 库 ， 例 如 MySQL、Access、SQL Server、 
acle、DB2 等 。 其 中 PHP 与 MySQL 的 组 合 堪 称 最 佳 搭档 ， 可 以 跨 平 台 运行 。 
@ 可 以 与 多 种 协议 进行 通信 ， 包 括 IMAP、POP3、SMTP、SOAP、DNS 等 。 

可 以 实现 对 XML 文档 进行 有 效 管理 及 创建 和 调用 Web 服务 等 操作 。 

@ ”可 以 使 用 正则 表达 式 解 析 复 杂 字符 串 。 

(4) 面向 对 象 编程 。 

PHP 5.0 以 上 版 本 提供 了 面向 对 象 的 编程 方式 ， 不 仅 提高 了 代码 的 重用 率 ， 而 且 为 代 
码 维护 带 来 了 极 大 的 方便 。 

(5) 成 本 低 。 

PHP、MySQL 和 Apache(Apache 是 支持 PHP 运行 的 服务 器 软件 之 一 ) 都 属于 免费 软 
件 ， 在 很 多 网 站 上 都 可 以 随时 下 载 到 最 新 版 本 的 PHP 和 MySQL 。 采 用 
Apache+PHP+MySQL 这 种 框架 结构 可 以 为 网 站 经 营 者 节省 很 大 的 开支 。 


1.1.2 PHP 脚本 程序 工作 流程 


@ 
日 忆 




















如 | 


运行 PHP 程序 ， 必 须 借助 PHP 预 处 理 器 、Web 服务 器 和 Web 浏览 器 ， 必 要 时 还 要 借 
助 数 据 库 服务 器 。 其 中 ，Web 服务 器 的 功能 是 解析 HITP，PHP 预 处 理 器 的 功能 是 解释 
PHP 代码 ，Web 浏览 器 的 功能 是 显示 PHP 程序 的 执行 结果 ， 数 据 库 服 务 器 的 功能 是 保存 
执行 结果 。 

1. Web 浏览 器 


Web 浏览 器 (Web BrowseD 也 称 为 网 页 浏览 器 ， 简 称 浏览 器 。 浏 览 器 是 用 户 最 常用 的 客 
户 端 程序 ， 主 要 功能 是 显示 HTML 网 页 内 容 ， 并 让 用 户 与 网 页 内 容 产生 互动 ， 常 用 的 浏览 
器 有 下 、Chrome、Firefox 等 。 

2. HTML 简介 


HTML 是 网 页 的 静态 内 容 ， 这 些 静 态 内 容 是 由 一 些 标记 产生 的 ，Web 浏览 器 识别 并 解 
释 执行 这 些 HIML 标记 。 在 PHP 程序 开发 过 程 中 ，HTML 主要 负责 页 面 的 互动 、 布 局 和 
美化 。 


3. PHP 预 处 理 器 


PHP 预 处 理 器 (PHP Preprocessor) 的 功能 是 将 PHP 程序 中 的 PHP 代码 解释 为 文本 信 
息 ， 这 些 文本 信息 可 以 包含 HTML 代码 。 

4. Web 服务 器 

Web 服务 器 (Web Server) 也 称 为 WWW(World Wide Web) 服 务 器 ， 其 功能 是 解析 
HTTP。 当 Web 服务 器 接收 到 浏览 器 的 一 个 HITP 动态 请 求 时 ，Web 服务 器 会 调用 与 请 求 


对 应 的 程序 。 程 序 经 PHP 预 处 理 器 解释 执行 后 ，Web 服务 器 向 浏览 器 返回 HITP 响应 ， 
该 响应 通常 是 一 个 HTML 页 面 。 浏 览 器 接收 到 该 HTTP 响应 后 ， 将 执行 结果 显示 在 浏览 器 
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或 进行 其 他 处 理 。 

常见 的 Web 服务 器 有 微软 的 IIS(Intemet Information Services) 服 务 器 、 开 源 的 Apache 
服务 器 等 。 由 于 Apache 具有 免费 、 速 度 快 且 性 能 稳定 等 特点 ， 已 成 为 目前 最 为 流行 的 
Web 服务 器 。 本 书 也 采用 Apache 服务 器 部 署 PHP 程序 。 


5. 数据 库 服务 器 


数据 库 服 务 器 (Database ServeD 是 一 套 为 应 用 程序 提供 数据 管理 服务 的 软件 ， 这 些 服务 
主要 包括 数据 管理 服务 (例如 ， 数 据 的 添加 、 删 除 、 修 改 、 查 询 )、 事 务 管 理 服务 、 索 引 服 
务 、 高 速 缓存 服务 、 查 询 优化 服务 、 安 全 及 多 用 户 存 取 控制 服务 等 。 

常见 的 数据 库 服务 器 有 甲骨 文公 司 的 Oracle 和 MySQL、 微 软 公司 的 SQL Server、 
IBM 公司 的 DB2 等 。 由 于 MySQL 具有 体积 小 、 速 度 快 、 免 费 等 特点 ， 很 多 中 小 型 Web 
系统 都 首选 MySQL 作为 数据 库 服 务 器 。 本 书 也 选用 MySQL 来 讲解 有 关 PHP 应 用 程序 中 
数据 库 开发 方面 的 知识 。 

6. PHP 程序 的 工作 流程 

PHP 程序 的 工作 流程 如 图 1-1 所 示 ， 具 体 步骤 如 下 。 


wb 服务 回响 应. 
数据 库 服务 器 























浏览 器 态 页 面 
天 人 和 @-2 PHP 预 处 理 器 
人 0 机 国 请求 处 理 PHP 数据 库 操 
OE Oh 作 代码 时 需要 和 数 

态 页 面 态 页 面 据 库 交 互 






@-1 当 请 求 页 面 为 动 
态 页 面 时 ， 需 要 将 该 
页 面 经 PHP 预 处 理 
器 处 理 


@web 服务 器 


动态 网 页 静态 网 


和 sseeseeseeseeeoereeroereesseeseos : 





1-1 PHP 程序 的 工作 流程 


用 户 在 浏览 器 中 输入 要 访问 的 网 址 ， 回 车 后 触发 该 页 面 的 请 求 ， 并 将 请 求 传送 给 Web 
服务 器 (步骤 @D)。 

Web 服务 器 接收 到 请 求 后 ， 根 据 页 面 文件 名 在 Web 服务 主机 器 中 查找 对 应 的 文件 名 
(步骤 @)， 并 根据 请 求 页 面 文件 名 的 后 绥 ( 例 如 html 或 php) 判 断 当前 请 求 为 静态 页 面 请 求 还 
是 动态 页 面 请 求 。 

当 请 求 页 面 为 静态 页 面 时 (例如 页 面 文件 名 的 后 绥 为 htm 或 .html)， 直 接 将 Web 服务 器 
中 的 静态 页 面 返回 (步骤 @)， 并 将 该 页 面 作为 响应 发 送 给 浏览 器 (步骤 @)。 

当 请 求 的 页 面 为 动态 页 面 时 (例如 请 求 页 面 文件 名 后 组 为 php)，Web 服务 器 委托 PHP 
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预 处 理 器 将 该 动态 页 面 中 的 PHP 代码 解释 为 文本 信息 (步骤 @-D); 如 果 动 态 页 面 中 存在 数 
据 库 操作 代码 ，PHP 预 处 理 器 和 数据 库 服务 器 完成 信息 交互 (步骤 @@-2) 后 ， 再 将 动态 页 面 
解释 为 静态 页 面 (步骤 @-3); 最 后 Web 服务 器 将 该 静态 页 面 作 为 响应 发 送 给 浏览 器 ( 步 
又 @)。 




















1.2 开发 工具 


在 运行 PHP 程序 前 ， 需 要 安装 、 配 置 Web 服务 器 以 及 数据 库 服务 器 。 目 前 常用 的 
Web 服务 器 是 开源 的 Apache 服务 器 ， 数 据 库 服务 器 是 MySQL 数据 库 服务 器 。 其 中 
Apache、PHP 以 及 MySQL 的 安装 软件 均 可 以 单独 下 载 、 安 装 。 为 了 便于 教 与 学 ， 本 书 采 
用 Apache+PHP+MySQL 集成 系统 。 目 前 较为 流行 的 集成 系统 有 XAMPP、WAMP、 
APMServ 等 。 


1.2.1 集成 系统 的 安装 与 启动 





1. XAMPP 


XAMPP 是 一 个 功能 强大 的 Apache+PHP+MySQL 集成 系统 ， 它 包含 Apache、PHP、 
MySQL 和 Perl， 可 以 在 Windows、Linux、Solaris、Mac OS X 等 多 种 操作 系统 下 安装 使 
用 ， 支 持 英文 、 中 文 、 日 文 、 韩 文 等 多 种 语言 。 

(1) XAMPP 的 下 载 。 

XAMPP 官方 下 载 网址 是 https://www.apachefriends.org， 登 录 官 方 网 站 后 ， 点 击 下 载 链 
接 即 可 下 载 ， 如 图 1-2 所 示 。 


XAMPP now supports PHP 7! 











1-2 XAMPP 官网 下 载 页 面 


(2) XAMPP 的 安装 。 
下 载 XAMPP 安装 软件 包 后 ， 双 击 该 安装 文件 即 可 进入 安装 进程 。 安 装 过 程 中 只 需 确 
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定安 装 XAMPP 的 路 径 ， 然 后 依次 单 击 “ 下 一 步 ” 按 钮 即 可 完成 安装 。 

(3) XAMPP 的 启动 。 

单 击 Windows 操作 系统 的 “开始 ”按钮 ， 在 “所 有 程序 ”中 单 击 项 目 XAMPP 中 的 
XAMPP Control Panel 或 者 将 其 制 成 一 个 快捷 图 标 置 于 桌面 上 ， 然 后 双击 该 快捷 图 标 园 即 
可 启动 XAMPP。 分 别 单 击 Apache 和 MySQL 右 侧 对 应 的 Start 按钮 ， 就 可 以 启动 Apache 
和 MySQL 数据 库 服务 器 ， 如 图 1-3 所 示 。 


图 zhtpP_ Control Panel v3.2.2 [ Coopiled: Wov 12th 2015 ] 
XAMPP Control Panel v3.2.2 SF corto 
E Module PID(S) Portls) Actions green | 
Apache Ss aa sop | aum | com | ts | 画 sm | 
MySQL 6084 3308 Admin | Confg | Logs Explorer 
st | so | cam | ts Services 
Wercury san | om | conmg | Logs Hep 
Tomeat sar | so | conmg | Logs 国 om 
All prerequisites found 
Initializing Modules 
Starting Check-Tiner 


Control Panel Ready 
Attenpting to start Apache app... | 
























EEE 
; 


Attenpting to start MySQL app... 
Status change detected: running 
Status change detected: rumming 








[nysql] 











1-3 XAMPP 控制 面板 


本 书 中 的 PHP 程序 均 在 XAMPP 系统 下 调试 运行 。 
启动 浏览 器 ， 在 地 址 栏 输入 http://localhost 或 者 http://127.0.0.1， 若 出 现 如 图 1-4 所 示 
的 页 面 ， 则 说 明 Apache 正常 启动 。 





XAMPP Apache + MariaDB + PHP + Perl 


Welcome to XAMPP for Windows 7.0.1 








rt ihe XAMPP Conitrol Panal ho check pa server stants 


Community 
wy 。 






Contribute to XAMPP translation at translate.apachefri 





Install applications on XAMPP using Bitnami 








1-4 测试 Apache 服务 器 是 否 正常 启动 
蔷 提示 : XAMPP 的 Web 路 径 位 于 XAMPP 安装 路 径 下 的 htdocs 文件 天 下 ， 编 辑 好 
的 PHP 程序 文件 存放 在 该 文件 天 下 就 可 以 在 浏览 器 上 调用 了 。 
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2. WAMP 

(1) WAMP 的 下 载 。 

WAMP 也 是 目前 广 为 应 用 的 Apache+PHP+MySQL 集成 系统 之 一 ， 它 的 官方 下 载 网 址 
是 http://www.wampserver.com/en， 单 击 页 面 上 的 下 载 链 接 就 可 以 下 载 WAMP 安装 包 ， 如 
图 1-5 所 示 。 





© crese aasbdreaamy wew and pu yo PP Mes moe 
Crontne cafesrme ne， am or open Tour 
enet wowser 了 的 全 We UR Mp Cg 


WRMPSERVER 











1-5 WAMP 官方 下 载 网 页 


(2) WAMP 的 安装 。 

双击 WAMP 的 安装 软件 ， 确 定安 装 WAMP 的 路 径 后 ， 依 次 单 击 “ 下 一 步 ” 按 钮 即 可 
完成 安装 过 程 。 

(3) WAMP 的 启动 。 

双击 桌面 上 的 快捷 图 标 候 ， 启 动 WAMP， 然 后 用 鼠标 右 击 右 下 角 任 务 栏 上 的 图 标 
国 ， 进 入 WAMP 的 控制 界面 ， 如 图 1-6 所 示 ， 选 择 “ 启 动 所 有 服务 (U)” 或 “重新 启动 所 
有 服务 (X)” 命 令 即 可 。 

















启动 所 有 季 务 (U) 
停止 所 有 最 务 (V) 
Ea | 


切换 到 在 颖 状 术 人 ) 


WAMPSERVER 2.5 


1-6 WAMP Server 控制 界面 
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启动 浏览 器 ， 在 地 址 栏 输入 http://localhost 或 者 http://127.0.0.1， 车 出 现 如 图 1-7 所 示 
的 页 面 ， 则 说 明 Apache 正常 启动 。 
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WampServer 
Vain 2 Veriom rmmomi 
Server Configuration 
Apache Version : 2.4.9 ~ Documentation 
Php Version 55.12 ~ Documentation 
Server Software: Apachs/2.4.9 [Win32] PHF/5.5.12 
onded Pqenslons; 办 apeinahande 入 Kmath 办 bm de 得 con dan 
办 com 办 cp 竹 cl dane 和 sm 
办 ma pe 办 Pen 检 phe 页 避 
Ee 办 orrer 办 omp 认 ham 而 imv 
办 mop 办 Pon 让 bm 办 monrg 而 moypt 
办 mm 办 mm 办 moh 内 mand 办 omr 
办 opene 办 pae 办 FOOD 击 poa maq 办 pco sq 
斩 Prar 办 Refecnon 圭 smson 机 shmop 办 SmplexwL 
办 soap 办 mca 办 Sr 让 dre 击 sbnczrd 
办 rokenmnr 办 waar 办 xcebug Pe 界 wmireader 
容 znwpc 鹤 zmiwnter 筑 革 要 光 LE 





MySQt varslon :55.17 - Documentation 


Tools Your Projects Your Aliases 
phpnto0 opmkcsye phpmyadmin 
phpmyadmin To creats a new one Just aeatea crectory n = phpsysinfo 
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苇 提示 : WAMP 的 Web 路 径 位 于 WAMP 安装 路 径 下 的 www 文件 天 下 ， 编 辑 好 的 
PHP 程序 文件 存放 在 该 文件 夹 下 就 可 以 在 浏览 器 中 调用 了 。 

1.2.2 PHP 程序 开发 工具 


1. Dreamweaver 


Dreamweaver 是 Macromedia 公司 开发 的 Web 站 点 和 应 用 程序 的 专业 开发 工具 ， 它 将 
可 视 布 局 工具 、 应 用 程序 开发 和 代码 编辑 功能 组 合 在 一 起 ， 可 以 开发 静态 网 页 、PHP 网 
页 、JSP 网 页 和 ASPNET 网 页 ， 是 目前 最 流行 的 网 页 开发 工具 之 一 。 

2. Zend studio 


Zend Studio 是 常用 的 开发 PHP 程序 的 集成 开发 环境 ， 有 具备 功能 强大 的 专业 编辑 工具 
和 调试 工具 ， 支 持 PHP 语法 加 亮 显示 ， 支 持 语法 自动 填充 功能 ， 支 持 书签 功能 ， 支 持 语 法 
自动 缩 排 和 代码 复制 功能 ， 支 持 本 地 和 远程 两 种 调试 模式 ， 支 持 多 种 高 级 调试 功能 。Zend 
Studio 可 以 在 Linux、Windows 以 及 Mac OS X 系统 上 运行 。 











3. FrontPage/SharePoint Designer 

FrontPage 是 微软 公司 出 品 的 一 款 网 页 制作 入 门 级 软件 。FrontPage 的 使 用 方便 简单 ， 
会 用 Word 就 能 利用 FrontPage 做 网 页 ， 因 此 相对 于 Dreamweaver，FrontPage 更 容易 上 
手 ， 具 有 所 见 即 所 得 的 特点 ， 该 软件 结合 了 设计 、 程 式 码 和 预览 三 种 模式 。SharePoint 
Designer 是 微软 推出 的 替代 FrantPage 的 新 一 代 网 站 开发 工具 ， 它 提供 了 与 时 俱 进 的 功能 ， 


ey. 
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能 让 企业 用 户 很 方便 地 给 网 站 添加 丰富 的 多 媒体 和 互动 性 体验 。 
PHP 程序 的 编辑 软件 还 有 很 多 ， 各 具 特 色 ， 例 如 写字 板 、EditPlus、Eclipse 等 ， 爱 好 
者 只 需 熟 练 掌握 其 中 一 种 就 可 以 写 出 优美 的 PHP 程序 了 。 


1.3 PHP 语法 基础 


PHP 是 一 种 在 服务 器 端 执 行 的 内 嵌 式 的 脚本 语言 ，PHP 代码 可 以 嵌入 到 HTML 代码 
中 ，HTML 代码 也 可 以 嵌入 到 PHP 代码 中 。 


1.3.1 PHP 标记 符 





在 PHP 程序 中 ， 所 有 的 PHP 代码 必须 位 于 开始 标记 和 结束 标记 之 间 ， 这 是 书写 PHP 
代码 必须 遵循 的 基本 规则 。 两 个 标记 之 外 的 所 有 文本 都 会 被 解释 为 普通 的 HTML。PHP 
预 处 理 器 只 针对 PHP 代码 进行 分 析 、 处 理 。PHP 标记 符 共 分 四 种 ， 它 们 的 标记 作用 是 等 
效 的 。 

1. 标准 风格 

<?php 

echo "这 是 PHP 标准 标记 风格 "; 
人 


标准 风格 的 标记 以 “<?php” 开 始 ， 以 “?>” 结 尾 ， 中 间 包 含 的 代码 就 是 PHP 语言 代 
码 。 本 书 使 用 的 就 是 标准 风格 ， 也 是 PHP 推荐 使 用 的 编程 风格 ， 它 在 XML、XHTML 中 
都 可 以 使 用 。 


2. 脚本 风格 





<script language="php"> 
echo "这 是 PHP 脚本 标记 风格 "; 
</script> 
脚本 标记 风格 以 “<script>” 开 头 ， 以 “</script>” 结 尾 ， 在 XML 和 XHTML 中 也 推 
荐 使 用 这 种 标记 风格 ， 它 符合 XML 语言 规范 的 写法 。 
3. 简短 风格 
Es 
echo "这 是 PHP 简短 标记 风格 "; 
2> 
这 种 标记 风格 最 为 简单 ， 若 想 使 用 这 种 标记 风格 开发 PHP 程序 ， 就 必须 保证 PHP 配 
置 文件 php.ini 中 的 short_ open_tag 选项 值 设置 为 on。 
4. ASP 风格 


< 条 
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echo "这 是 ASP 标记 风格 "; 
务 > 


这 种 标记 风格 与 ASP 相同 ， 不 推荐 使 用 这 种 标记 风格 。 若 想 使 用 这 种 标记 风格 ， 必 须 
保证 PHP 配置 文件 php.ini 中 的 asp_tags 选项 值 设置 为 on。 
1.3.2 PHP 注释 


注释 可 以 理解 为 代码 中 的 解释 和 说 明 ， 是 程序 中 不 可 缺少 的 重要 元 素 。PHP 注释 和 
PHP 代码 相同 ， 必 须 位 于 PHP 的 开始 标记 与 结束 标记 之 间 ，PHP 预 处 理 器 不 会 处 理 PHP 
注释 内 容 。PHP 支持 以 下 三 种 注释 风格 。 


1. C++ 风格 的 单行 注释 (//) 





<?php 
//echo "这 是 C++ 注 释 风 格 "; 
?> 


CH 风格 的 单行 注释 以 “/” 开始， 到 该 行 结束 的 内 容 都 是 注释 。 
2. C 风格 的 多 行 注 释 (/*.….*/) 
<?php 
/* 
echo "第 一 行 注释 "; 
echo "第 二 行 注释 "; 
A 
echo "这 是 C 语 言 的 多 行 注释 "; 
?> 
C 风格 的 多 行 注 释 以 “/*” 开 始 ， 以 “*/” 结 束 。 与 C 语言 相同 ， 多 行 注释 不 允许 嵌 套 。 
3. Shell 风格 的 单行 注释 (#) 


<?php 
echo "这 是 shel1 风格 的 注释 "; ”#shell 风格 注释 
> 


Shell 风格 的 单行 注释 以 “# ”开始 ， 到 该 行 结束 的 内 容 都 是 注释 。 
1.3.3 PHP 语句 与 语句 块 


1. PHP 语句 


PHP 程序 一 般 由 若干 条 PHP 语句 组 成 ， 每 条 PHP 语句 均 以 分 号 “:” 结 束 ， 只 有 PHP 
结束 标记 之 前 的 PHP 语句 可 以 省 略 分 号 。 

书写 PHP 代码 时 ， 一 般 情况 下 一 条 语句 占 一 行 ， 但 是 也 允许 在 一 行 上 书写 多 条 PHP 
语句 。 
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2. PHP 语句 块 
若 多 条 PHP 语句 之 间 密 不 可 分 ， 可 以 使 用 “{” 和 “}” 将 这 些 语句 包含 起 来 形成 语句 
块 。 例 如 : 
<?php 
if ($a>2) 
{ 


$a=$b-2; 
echo $a,sb; 


?> 


语句 块 常常 应 用 于 条 件 控制 语句 (if...else)、 循 环 语句 (for、while) 和 函数 中 。 
1.3.4 PHP 输出 指令 


1. echo 语句 

echo 语句 是 PHP 中 最 常用 的 语句 ， 其 功能 是 将 一 个 或 多 个 表达 式 的 值 输出 到 页 面 
上 。 语 法 格式 为 : 

echo "string argl,.., string [argn].." 

echo 语句 会 将 传 入 的 argl1、arg2、...、argn 等 参数 的 值 输出 到 网 页 上 。 例 如 ， 在 网 页 
上 输出 字符 串 “ 你 好 ! PHP”， 代 码 如 下 : 


<?php 
echo "你 好 ! PHP"; 





Ds 
echo 语句 可 以 一 次 输出 多 个 值 ， 各 个 值 之 间 要 以 逗号 分 隔 。 例 如 : 
<?php 
echo "计算 结果 : " ,1+2+3+4+57 
浏览 器 上 显示 的 结果 为 : 
计算 结果 : 15 
2. print ( ) 语 句 
print( ) 语 句 的 功能 是 将 字符 串 输出 到 浏览 器 或 打印 机 等 输出 设备 。 语 法 格式 为 : 
int print( string arg) 
该 语句 执行 成 功 返 回 1， 失 败 返回 0。 
print( ) 语 句 一 次 只 能 输出 一 个 字符 串 。 例 如 ， 在 浏览 器 上 输出 “你 好 ! PHP”， 代 码 如 下 : 
<?php 


print ("你 好 ! PHP"); 
2> 
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3. printf( ) 语 句 
printf( ) 语 句 以 格式 化 的 方式 输出 字符 串 ， 其 语法 格式 如 下 : 
int printf(string format[,mixed args[,mixed...]] 


printf( ) 语 句 按照 参数 format 指定 的 内 容 格式 对 字符 串 进行 格式 化 ， 具 体 参数 format 

















的 转换 格式 是 以 “%” 开 始 到 转换 字符 为 止 。 参 数 format 的 格式 转换 类 型 如 表 1-1 所 示 。 


表 1-1 参数 format 的 格式 转换 类 型 








参 数 说 明 
b 整数 转换 为 二 进 制 
c 整数 转换 为 对 应 的 ASCII 码 
d 整数 转换 为 十 进 制 
f 将 被 精确 度数 字 转 换 为 浮 点 数 
o 整数 转换 为 八进制 
s 整数 转换 为 字符 串 
x 整数 转换 为 小 写 十 六 进 制 
苞 整数 转换 为 大 写 十 六 进 制 
下 面 应 用 printf ) 语 句 将 整数 转换 为 不 同 的 类 型 ， 并 以 格式 化 的 方式 输出 字符 串 。 
<?php 
printf ("%c",120); // 将 整数 转换 为 字符 
printf("%0.2f",125); // 将 整数 转换 为 包含 两 位 小 数 的 浮 点 数 
printf ("%s",234); // 将 整数 转换 为 字符 串 
printf ("%x", 456); // 将 整数 转换 为 大 写 十 六 进 制 
2 


浏览 器 上 显示 的 结果 为 : 


X125.002341C8 


1.3.5 ”PHP 编码 规范 


养 成 良好 的 编程 习惯 ,能够 提高 代码 的 质量 和 编写 的 效率 。 不 良 的 编程 习惯 经 常会 造 


成 代码 缺陷 ， 使 得 程序 难以 维护 ， 甚 至 在 维护 时 又 可 能 引入 新 的 缺陷 。 因 此 书写 PHP 代码 
时 需要 遵循 一 些 基本 的 编码 规范 。 
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1. 书写 规范 

(1) 缩 进 。 

使 用 Tab 键 ( 制 表 符 ) 缩 进 ， 缩 进 单 位 为 4 个 空格 。 

(2) 大 括号 { }。 

大 括号 经 常 与 选择 语句 (if...else)、 循 环 语句 (for、while) 配 合 使 用 ， 构 成 语句 块 。 
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(3) 关键 字 、 小 括号 、 函 数 、 运 算 符 。 

@ 尽量 将 小 括号 与 关键 字 用 空格 隔 开 。 例 如 : 
if ($a>2) 
下 


@ ”小 插 号 与 函数 名 不 要 隔 开 ， 以 便 区 分 开关 键 字 和 函数 。 例 如 : 
empty ($string) 
@ ”使 用 retum 返回 语句 时 ， 不 要 使 用 小 括号 。 例 如 : 


return 1; 


2. 命名 规范 


使 用 良好 的 命名 也 是 重要 的 编程 习惯 ， 良 好 的 名 称 可 以 使 程序 代码 更 容易 阅读 、 理 解 
和 维护 。 命 名 遵循 的 基本 原则 是 : 以 英文 单词 为 蓝本 ， 尽 量 不 要 使 用 拼音 或 拼音 和 英文 混 
杂 的 命名 方式 。 命 名 要 尽量 简短 ， 含 义 一 目 了 然 。 

(1) 类 。 

@ 类 名 的 首 字母 使 用 大 写 形式 ， 其 他 的 尽量 使 用 小 写 形式 。 

@ 尺 量 不 要 使 用 下 夯 线 “_”。 

例如 : ObjectName、MyDatabase。 

(2) 常量 。 

常量 名 的 所 有 字母 均 要 大 写 ， 单 词 间 以 下 划 线 “ ”分 隔 。 例 如 : 

NULL、TRUE、MY_NAME 等 。 

(3) 变量 。 

@ ”所 有 字母 都 建议 使 用 小 写 形式 。 

@ ”使 用 下 画 线 “ ”作为 每 个 单词 的 分 隔 符 。 

@ 同一 个 软件 系统 ， 变 量 的 命名 规则 必须 统一 。 


1.4 综合 实 训 案例 


本 节 主 要 介绍 创建 一 个 简单 PHP 程序 的 具体 步骤 ， 该 程序 运行 后 会 在 浏览 器 上 输出 以 
下 内 容 : 


你 好 ! PHP 和 


广大 女友 大 而 坟 支 去 大 庆 到 太太 击 大 支 支 坟 赤 友 坟 


具体 步骤 如 下 。 
1. 启动 Apache 
启动 XAMPP 控制 面板 ， 单 击 Apache 右 侧 对 应 的 Start 按钮 ， 如 图 1-8 所 示 。 


3. 
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7 [Apachs] Status change detected: runing 








图 1-8 启动 Apache 


2. 编辑 PHP 代码 

打开 PHP 程序 编辑 器 (如 写字 板 、 记 事 本 、Dreamweaver 或 Zend Studio 等 )， 在 新 创建 
的 文件 中 输入 代码 : 

<?php 


Ch mm 坟 太太 夫 克 交 克 太太 友 太太 友 友 大昌，<DI/>"> 


echo "* 你 好 ! PHP *","<br/>"; 
echo 四 友 方 方 文 方 方 文 方 方 广 方 码 文 方 文明 了 


2> 

说 明 : 

程序 中 的 <br/> 是 HTML 标记 符号 ， 表 示 换 行 的 意思 。 

将 文件 保存 到 XAMPP 安装 文件 夹 下 的 htdocs 文件 夹 下 ， 文 件 的 扩展 名 为 .php， 如 
example_1.php。 

3. 运行 PHP 程序 


启动 浏览 器 (如 正 )， 在 地 址 栏 中 输入 http://localhost/example 1.php 或 者 
http://127.0.0.1/example_1.php 后 回 车 。 在 浏览 器 中 会 看 到 输出 的 字符 串 “ 你 好 ! PHP”， 
程序 运行 效果 如 图 1-9 所 示 。 








园 1ocalhost /onanple 1 phe x Ws 
C localhost/example_l1 


二 


站 你 好 ! PHP * 


4 





图 1-9 程序 运行 效果 
[对 提示 : 有 时 在 浏览 器 中 看 到 的 结果 为 乱码 ， 其 原因 是 ， 由 于 PHP 程序 使 用 的 字符 
集 与 浏览 器 使 用 的 字符 集 不 匹配 造成 的 。 此 时 需要 将 浏览 器 使 用 的 字符 集 
和 PHP 程序 使 用 的 字符 集 改 为 统一 的 简体 中 文字 符 集 (gb2312 或 gbk).。 
.TAN， 
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方法 一 : 在 PHP 程序 的 开始 部 位 添加 语句 。 
header ("Content-Type:text/html;charset=gb2312"); 
上 述 PHP 程序 可 以 写 为 : 


<?php 
header ("Content-Type:text/html;charset=gb2312"); 
Ch 由 太太 太太 太太 太太 太太 方太 大 目 mv<CDIA/ > 


echo "* 你 好 ! PHP *","<br/>"; 
ChO mm 六 太太 大 大友 太太 坟 赤 太 中 了 


党 汪 

方法 二 : 打开 正 浏览 器 的 菜单 项 “查看 ”|“ 编 码 ”， 将 浏览 器 的 编码 改 为 “简体 中 
文 (GB2312)” 即 可 。 

有 关 PHP 程序 中 字符 集 的 设置 方法 将 在 后 续 章 节 中 详细 讲解 。 


本 章 小 结 


本 章 介绍 了 PHP 的 特点 及 发 展 过 程 ， 集 成 开发 环境 的 安装 与 使 用 ， 以 及 PHP 语法 基 
础 知识 。 读 者 应 重点 掌握 PHP 的 语法 结构 、 输 出 语句 的 应 用 。 


习 题 


1. 下 载 并 安装 XAMPP， 启 动 XAMPP 控制 面板 完成 以 下 操作 。 
(1) 启动 Apache、MySQL， 启 动 浏览 器 ， 测 试 Apache 是 否 能 正常 启动 。 
(2) 关闭 Apache、MySQL.。 
2. 创建 PHP 程序 ， 输 出 表达 式 1+2-3+4-5 的 计算 结果 。 
3. 编写 程序 ， 在 页 面 上 输出 以 下 内 容 。 
你 好 ! 
PHP 程序 设计 
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本 章 要 点 

@ PHP 常量 、 交 量 

@ PHP 数据 类 型 

@ PHP 运 算 符 及 表达 式 

学 习 目 标 

@ 掌握 PHP 常量 与 变量 的 概念 及 应 用 方法 
@ 掌握 PHP 数据 类 型 的 概念 

@ 掌握 PHP 运 算 符 及 表达 式 的 应 用 


2 量 
常量 是 指 在 程序 运行 中 其 值 始 终 保持 不 变 的 量 。 常 量 一 经 定义 ， 常 量 的 值 以 及 常量 的 
数据 类 型 在 程序 中 不 得 被 修改 和 注销 。 常 量 分 为 自 定义 常量 和 预定 义 常量 。 
2.1.1 自 定义 常量 


自 定 义 常 量 在 使 用 前 必须 要 先 定 义 。PHP 中 定义 常量 可 以 使 用 defineO 函 数 来 实现 。 
define() 函 数 的 语法 格式 如 下 : 
define (string constant name,mixed value,bool case_sensitive) 
define() 函 数 的 参数 说 明 如 表 2-1 所 示 。 
表 2-1 define() 的 参数 说 明 
说 明 














参 数 
constant_name 常量 名 称 ， 为 字符 串 类 型 的 数据 
常量 的 值 ， 必 须 为 布尔 型 (boolean)、 字 符 串 型 (string)、 整 型 (integer) 和 浮 点 型 
(floa0) 等 类 型 的 数据 


可 选 。 规 定 大 小 写 是 否 敏感 ， 默 认为 FALSE， 表 示 大 小 写 敏感 


value 
case_sensitive 
【实例 2-1】 定 义 并 输出 自 定义 常量 。 
<?php 


define ("MY NAME","John"); 
echo MY_NAME; 





人 > 
结果 为 : 
John 
避 提示 : 。 自 定义 常量 必须 使 用 define() 定 义 ， 常 量 名 称 前 不 需要 加 $ 符 号 。 
。@ 自 定义 常量 的 名 称 由 字母 或 下 画 线 开 头 ， 其 后 可 由 字母 、 数 字 、 下 画 线 
组 合 。 
。 自 定义 常量 的 作用 域 是 全 局 的 ， 不 存在 范围 的 问题 ， 可 以 在 程序 的 任意 
位 置 定义 和 使 用 。 
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2.1.2 ”预定 义 常量 


预定 义 常量 


是 PHP 预先 定义 的 常量 ， 通 过 预定 义 常量 可 以 获取 PHP 中 的 信息 。 常 见 


的 预定 义 常量 及 其 作用 如 表 2-2 所 示 。 


表 2-2 预定 义 常量 及 其 作用 

















参 数 说 明 
-=JFIE (FILE 前 后 是 两 个 下 画 线 ) 当 前 正在 处 理 的 PHP 程序 文件 名 
__LINE__ (LINE 前 后 是 两 个 下 画 线 ) 当 前 正在 处 理 的 文件 的 当前 行 数 
PHP_VERSION 当前 PHP 预 处 理 器 的 版 本 
PHP_OS PHP 所 在 的 操作 系统 的 类 型 
ROE | 名 直 
_FALSE | 如 候 
E ERROR 最 近 的 错误 处 一 ”MM 和 
E_WARNING 最 近 的 警告 处 
E_PARSE 解析 语法 存在 的 潜在 问题 处 
E_NOTICE 发 生 异常 ， 但 不 一 定 是 错误 处 
【实例 2-2】 显 示 预 定义 常量 信息 
<?php 
header ("Content-Type:text/html;charset=gb2312"); 
echo "当前 文件 : ",，__FILE _,"<br/>"; 
echo "当前 行 数 : ",，__LINE__,"<br/>"; 
echo "当前 PHP 版 本 : ", PHP_VERSION, "<br/>"; 
echo "当前 操作 系统 : ", PHP_OS; 
?> 
程序 运行 结果 如 图 2-1 所 示 。 


当 前 操作 系统 ; liar 





2-1 实例 2-2 的 运行 结果 


2.1.3 ”检测 常量 是 否 已 被 定义 


在 PHP 中 可 以 使 用 defined0 函 数 来 判断 一 个 常量 是 否 已 经 被 定义 ， 其 语法 格式 如 下 : 


bool defined(string constants name) 
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若 常 量 constants_name 已 被 定义 ， 则 返回 值 为 TRUE， 否则 返回 FALSE。 
2.2 变 量 


变量 在 程序 中 是 用 来 存储 数据 的 。 变 量 通 过 变量 名 来 实现 对 内 存 数 据 的 读 取 。PHP 程 
序 中 的 变量 可 以 不 事先 定义 而 直接 使 用 ，PHP 在 使 用 变量 时 会 根据 上 下 文 由 系统 解释 器 来 
判断 变量 的 类 型 。 


2.2.1 变量 的 命名 


变量 的 命名 遵循 以 下 规则 。 

@ 变量 名 必须 以 美元 符号 $ 开 头 。 

@ 变量 名 的 第 一 个 字符 必须 是 字母 或 下 画 线 ， 其 后 可 以 是 字母 、 数 字 和 下 画 线 的 组 
合 ， 如 $userl_name。 


@ PHP 中 的 变量 名 区 分 大 小 写 ， 如 $a 和 $A 是 两 个 不 同 的 变量 名 。 


2.2.2 ”变量 的 赋值 
变量 赋值 就 是 给 变量 赋予 具体 的 数据 。 常 用 的 变量 赋值 方式 有 以 下 三 种 。 
1. 直接 赋值 
直接 赋值 就 是 使 用 “=” 符 号 将 值 直 接 赋 给 变量 。 例 如 : 
<?php 


$user="john"; 
$height=200; 
> 
2. 传 值 赋值 
传 值 赋 值 就 是 使 用 “=” 将 一 个 变量 的 值 赋 给 另 一 个 变量 。 例 如 : 
<?php 
$user="john"; 


$student=$user; 
2> 


3. 引用 赋值 

引用 赋值 就 是 将 源 变 量 的 内 存 地 址 赋 给 新 的 变量 。 引 用 赋值 意味 着 两 个 变量 都 指向 同 
一 个 数据 ， 此 时 若 改动 新 变量 的 值 ， 也 将 会 改变 源 变量 的 值 ， 反 之 亦 然 。PHP 通过 在 源 变 
量 前 加 “&” 符 号 实现 引用 赋值 。 引 用 赋值 的 语法 格式 如 下 : 


$newvar name=&$sourcevar name; 


例如 : 
.ao 





<?php 
$a=10; 
$b=&$a; 
echo "b=", $b ™ a="y. $ar"<br/>"s> 
$b=20; 
echo “b=", Sh” a Sabr/o"s 
区 


程序 运行 结果 如 图 2-2 所 示 。 





2-2 引用 赋值 的 运行 结果 


于 提示 : ” 当 执 行 到 “$b=&$a:” 时 ， 变 量 $b 指向 变量 $a， 此 时 变量 $b 和 $a 共用 一 个 
值 ; 当 执行 到 “Sb=20:” 时 ， 变量 Sb 的 值 发 生变 化 ， 导 致 变量 $a 的 值 也 
同时 发 生变 化 。 

2.2.3 变量 的 作用 域 

变量 的 作用 域 是 指 变量 的 适用 范围 。 变 量 必须 在 有 效 的 范围 内 使 用 ， 如 果 超 出 了 有 效 
范围 ， 变 量 就 失去 了 意义 。 根 据 变量 的 作用 域 ， 可 以 将 变量 分 为 局 部 变量 、 全 局 变量 和 静 
态 变量 。 变 量 的 作用 域 如 表 2-3 所 示 。 

表 2-3 变量 的 作用 域 








说 明 

在 函数 内 部 定义 的 变量 ， 其 作用 域 就 是 所 在 的 函数 
定义 在 所 有 函数 之 外 的 变量 ， 其 作用 域 是 整个 PHP 文件 ， 但 在 自 定义 函数 内 部 不 
可 以 使 用 ， 若 想 在 自 定义 函数 内 部 使 用 全 局 变量 ， 需 使 用 global 关键 字 声明 
在 函数 内 部 使 用 关键 字 static 声明 的 变量 。 该 变量 在 函数 结束 调用 后 仍 保留 上 一 次 
运行 的 值 

关于 变量 作用 域 的 具体 内 容 将 在 第 4 章 详细 讲解 。 
2.2.4 可 变 变 量 


可 变 变 量 是 一 种 特殊 的 变量 ， 这 种 变量 的 名 称 是 由 另外 一 个 变量 的 值 来 确定 的 。 声 明 
可 变 变量 的 语法 格式 如 下 : 
$$ 可 变 变量 名 称 = 可 变 变 量 的 值 ; 
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【实例 2-3】 可 变 变 量 示例 。 


<?php 
$a="hello"; 
$$a="world"; // 声 明 可 变 变量 ， 该 变量 的 名 称 为 变量 $a 的 值 
echo $a,"<br/>"; 
echo $$a, "<br/>"; // 等 价 于 echo $hello, "<br/>"; 
echo $hello; 
?> 


程序 运行 结果 如 图 2-3 所 示 。 


© |D localhost/example_2-3. php 





图 2-3 可 变 变 量 的 运行 结果 


[及 提示 :， 可 变 变 量 $$a 的 名 称 就 是 变量 $a 的 值 ， 因 此 ，$$a 的 名 称 就 是 Shello， 它 们 
的 值 都 是 world。 


2.3 PHP 数据 类 型 


计算 机 操作 的 对 象 是 数据 ， 每 一 个 数据 都 有 其 类 型 。PHP 的 数据 类 型 分 为 三 种 ， 标 量 
数据 类 型 、 复 合 数据 类 型 和 特殊 数据 类 型 。 


2.3.1 标量 数据 类 型 


标量 数据 类 型 是 数据 结构 中 最 基本 的 单元 ， 只 能 储存 一 个 数据 ， 包 括 布尔 型 
(boolean)、 字 符 串 型 (string)、 整 型 (integer) 和 浮 点 型 (float)。 

1. 布尔 型 (boolean) 

布尔 类 型 的 值 只 有 两 个 : 真 (TRUE) 和 假 (FALSE)。 

2. 字符 串 型 (string) 

字符 串 是 连续 的 字符 序列 ， 字 符 串 的 组 成 字符 包含 以 下 几 种 类 型 。 

@ ”字母 类 型 A、B、a、b 等 。 

@ ”数字 类 型 ，]、2 等 。 

@ ”特殊 字符 : #、*、+、^ 等 。 

@ 不 可 见 字符 :\n( 换 行 符 )、\r( 回 车 符 )、\t(Tab 字符 ) 等 。 

其 中 不 可 见 字符 是 用 来 控制 字符 串 格式 化 输出 的 一 种 特殊 字符 。 它 在 浏览 器 页 面 上 不 
可 见 ， 只 能 看 到 其 控制 的 字符 串 的 输出 结果 。 


22. 
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【实例 2-4】 通 过 字符 控制 输出 的 字符 串 。 
<pre> 
<?php 


header ("Content-Type:text/html;charset=gb2312"); 
echo "你 好 \nPHP 程序 设计 \rJSsP 程序 设计 "; 

a 

</pre> 


程序 运行 结果 如 图 2-4 所 示 。 


D localhost 


你 好 


PHP 程 序 设计 
JSP 程 序 设计 





2-4 实例 2-4 的 运行 结果 





字符 串 的 界定 符号 。 
e@ 。 单 引号 ()。 
@ 。 双 引号 (")。 


@。 界定 符 (<<<)。 


[时 提示 : 单 引 号 和 双 引 号 的 区 别 是 双 引号 中 包含 的 变量 会 被 自动 替换 成 实际 数值 ， 
而 单 引 号 包含 的 变量 则 按 普通 字符 串 输出 。 


中 存在 表 2-4 所 示 的 特殊 字符 时 ， 该 特殊 字符 会 被 转 义 成 对 应 的 字符 。 
表 2-4 ”特殊 字符 序列 


Ut 


当 字符 上 














双 引 号 内 的 特殊 字符 转 义 后 的 字符 
和 双 引 号 (") 
了 美元 符号 (9) 
\ 反 斜 杠 Q) 
un 换行 符 
Yr 回 车 符 
At 制 表 符 





【实例 2-S】 单 引号 、 双 引号 界定 字符 串 示例 。 


<?php 
header ("Content-Type:text/html;charset=gb2312"); 
$str="PHP 程序 设计 "; 
echo "$str"> "<br/>™s 
echo "Str ESD 
2 
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程序 运行 结果 如 图 2-5 所 示 。 





2-5 ”实例 2-5 的 运行 结果 


3. 整 型 (integer) 

整 型 数据 只 能 包含 整数 。 在 32 位 操作 系统 下 ， 有 效 范 围 是 -2 147 483 648 一 
2 147 483 647。 如 果 超 出 范围 发 生 整数 溢出 ， 则 当 float 类 型 处 理 ， 返 回 float 类 型 。 

整数 的 表示 方式 如 下 。 

@ 十进制 ， 123、-23。 

@ 八进制 :以 0 开头 的 整数 ， 如 0123。 

@ 十 六 进 制 : 以 “0x” 开 头 的 整数 ， 如 0x123。 

4. 浮 点 型 (float) 

浮 点 数 类 型 既 可 以 用 来 存储 整数 ， 也 可 以 存储 小 数 。 在 32 位 操作 系统 下 ， 其 有 效 范 
围 是 1.7E-308 一 1.7E+308。 

浮 点 数 的 表示 方式 如 下 。 

@ 标准 格式 : 3.14、-2.78。 

@ ”科学 计数 法 格式 : 312.43E5、3.6E-3。 


2.3.2 ”复合 数据 类 型 


复合 数据 类 型 包括 : 数组 (arrry) 和 对 象 (objecb。 

1. 数组 

数组 是 一 组 数据 的 集合 ， 可 以 包含 多 种 数据 : 标量 数据 、 数 组 、 对 象 、 资 源 以 及 PHP 
中 支持 的 其 他 语法 结构 。 

数组 中 的 每 个 数据 称 为 一 个 元 素 ， 每 个 元 素 都 有 一 个 唯一 的 编号 ， 称 为 索引 。 索 引 只 
能 由 数字 或 字符 串 组 成 。 元 素 的 值 可 以 是 多 种 数据 类 型 。 定 义 数组 的 语法 格式 如 下 : 

$array= ("valuel", "value2",...); 

或 

$array[key]="value"; 

或 

$array (keyl=>valuel, key2=>value2,...); 


其 中 参数 key 是 数组 元 素 的 索引 ，value 是 数组 元 素 的 值 。 











【实例 2-6】 数 组 元 素 的 定义 及 输出 。 


<?php 
header ("Content-Type:text/html;charset=gb2312"); 
$a[0]="PHP"; // 定 义 a 数组 的 第 一 个 元 素 
Sa // 定 义 a 数 组 的 第 二 个 元 素 
$a[2]="JAVA"; // 定 义 a 数 组 的 第 三 个 元 素 
$b=array (0=>"apple",1=>"orange", 2=>"grape");  ”// 定 义 b 数 组 
echo $a[0],"<br/>"; // 输 出 a 数组 的 第 一 个 元 素 的 值 
echo $b[1],"<br/>"; // 输 出 b 数组 的 第 二 个 元 素 的 值 

?> 

程序 输出 结果 如 图 2-6 所 示 。 





2-6 ”实例 2-6 的 运行 结果 


数组 声明 后 ， 数 组 中 的 元 素 个 数 可 以 自由 更 改 。 只 要 给 数组 赋值 ， 数 组 就 会 自动 增加 
长 度 。 

2. 对 象 (object) 

在 PHP 中 也 可 以 使 用 面向 对 象 的 编程 技术 ， 有 具体 内 容 将 在 第 13 章 详细 讲解 。 


2.3.3 ”特殊 数据 类 型 


特殊 数据 类 型 包括 : 资源 (resource) 和 空 值 (null)。 

1. 资源 (resource) 

资源 是 由 专门 的 函数 建立 和 使 用 的 。 它 是 一 种 特殊 的 数据 类 型 ， 由 程序 员 分 配 。 在 使 
用 资源 时 ， 要 及 时 释放 不 需要 的 资源 。 如 果 忘 记 释 放 资 源 ， 系 统 也 会 自动 启动 垃圾 回收 机 
制 ， 避 免 内 存 消耗 列 尽 。 

2. 空 值 (NULL) 

空 值 就 是 没有 为 变量 赋予 任何 值 。NULL 不 区 分 大 小 写 ， 变 量 被 赋予 空 值 有 以 下 三 种 
情况 : 

@ ”没有 赋予 任何 值 ; 

@ 研 子 nmull; 

@ 被 unset0 函 数 处 理 过 的 变量 。 


2.3.4 检测 数据 类 型 


利用 PHP 提供 的 检测 数据 类 型 的 函数 ， 可 以 对 数据 进行 类 型 检测 ， 以 确定 该 数据 属于 
.1[55 
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哪 种 数据 类 型 。 检 测 数据 类 型 的 函数 如 表 2-5 所 示 。 
表 2-5 检测 数据 类 型 的 函数 








检测 类 型 
检查 变量 是 否 为 布尔 类 型 
检查 是 否 为 字符 串 类 型 


伶 查 是 否 为 ; 





is_bool 





is_string 
















is_float, is_double 


















is_integer, is_int 检查 是 否 

is_null 检查 是 否 为 

is_array 检查 是 否 为 数组 类 型 

is_object 检查 是 否 为 对 象 类 型 

is_numeric 检查 是 否 为 数字 或 由 数字 组 成 的 字符 串 





2.4 PHP 运算 符 
运算 符 是 用 来 对 变量 、 常 量 或 数据 进行 计算 的 符号 。PHP 的 运算 符 包 括 算 术 运 算 符 、 
字符 串 运 算 符 、 赋 值 运 算 符 、 递 增 / 递 减 运算 符 、 比 较 运算 符 、 逻 辑 运 算 符 、 条 件 运算 符 、 
错误 控制 运算 符 、 位 运算 符 等 。 
2.4.1 算术 运算 符 


算术 运算 符 主 要 用 于 处 理 与 算术 运算 相关 的 操作 ， 常 用 的 算术 运算 符 如 表 2-6 所 示 。 














表 2-6 算术 运算 符 
操作 符 含 义 
一 取 负 运算 : -$a 
过 加 法 运算 : $a+$b 
一 减法 运算 : $a-$b 
乘法 运算 : $a*$b 
/ 除法 运算 : $a/$b 








取 余数 运算 : $a%$b 
说 明 : 使 用 % 求 余数 时 ， 余 数 的 正 负 号 取决 于 % 左 端 数 的 正 负 号 。 


2.4.2 ”字符 串 运 算 符 


字符 串 运 算 符 主要 用 于 处 理 与 字符 串 相 关 的 操作 。 字 符 串 的 运算 符 只 有 一 个 点 “.”， 
该 运算 符 用 于 将 两 个 字符 串 连 接 成 一 个 新 字符 串 。 例 如 : 


<?php 
header ("Content-Type:text/html;charset=gb2312"); 
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$a="php"; 

$b=" 程 序 设计 "; 

echo $a.$b; 
> 


程序 运行 结果 为 : 
php 程序 设计 
2.4.3 ”赋值 运算 符 
赋值 运算 符 主要 用 于 处 理 表达 式 的 赋值 操作 ， 赋 值 运算 符 如 表 2-7 所 示 。 





表 2-7 赋值 运算 符 
操作 符 含义 实 例 
= 赋值 运算 :将 右边 的 值 赋 给 左边 的 变量 Sa=3; 
二 加 : 将 右边 的 值 加 到 左边 $a+=$b; 等 价 于 $a=$at$b; 
= 减 : 将 右边 的 值 减 到 左边 $a-=$b; 等 价 于 $a=$a-$b; 
*= 乘 将 右边 的 值 乘 到 左边 $a*=$b; 等 价 于 $a=$a*$b; 
三 除 : 将 右边 的 值 除 到 左边 $a/=$b; 等 价 于 $a=$a/$b; 
= 连接 字符 : 将 右边 的 字符 连接 到 左边 $a.=$b; 等 价 于 $a=$a+$b; 
%= 取 余 数 : 将 右边 的 值 对 左边 取 余 数 $a%=$b; 等 价 于 $a=$a%$b; 
【实例 2-7】 赋 值 运算 示例 。 
<?php 
Sa=57 
$b=10; 
$a*=$b; // 等 价 于 $a=$a*b; 
echo $a; 
> 
程序 运行 结果 为 
50 


2.4.4 ”递增 /递减 运算 符 


递增 /递减 运算 符 就 是 让 变量 自行 加 1/ 减 1 的 操作 。 递 增 /递减 运算 符 包 括 : ++、--。 
递增 /递减 运算 主要 有 两 种 运算 操作 。 

@ 前 加 、 前 减 : ++$a、--$a。 即 $a 的 值 先 加 / 减 1， 然 后 再 返回 $a 的 值 。 

@ 后 加 、 后 减 : $a++、$a--。 即 先 返回 $a 的 值 ， 再 将 $a 的 值 加 1/ 减 1 。 

【实例 2-8】 递 增 / 递 减 运算 示例 。 


<?php 
$a=10; 
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$b=++$a; // 先 将 $a 的 值 加 1， 再 将 新 的 $a 的 值 赋 给 $b 
$c=$a——; // 先 将 $a 的 值 赋 给 $c， 再 将 $a 的 值 减 1 
echo '$b=",$b,"$a="', $a,"<br/>"; 

echo "Sc="7 Cr "9a=" 2 


2 


程序 运 


[对 提示 : 


结果 如 图 2-7 所 示 。 


$b=11 $a=11 
$c=11 $a=10 





2-7 ”实例 2-8 运行 结果 
e 程序 命令 “$b=++$a;” 等 价 于 以 下 两 条 命令 语句 : 


$a=$a+l; 
$b=$a; 


这 样 ，$a 的 值 由 10 变 为 1， 而 后 $b 的 值 也 变 为 11。 
@ 程序 命令 “$c=$a--;” 等 价 于 以 下 两 条 命令 语句 : 


$c=$a; 
$a=$a-l1; 


这 样 ，$c 的 值 等 于 $a 的 值 11， 而 后 $a 的 值 减 1 变 为 10。 


2.4.5 ”比较 运算 符 


比较 运算 符 就 是 对 两 个 变量 或 表达 式 的 值 进行 大 小 、 真 假 等 的 比较 。 比 较 的 结果 为 一 
个 布尔 类 型 值 (TRUE 或 FALSE)。 比 较 运算 符 如 表 2-8 所 示 。 




















表 2-8 比较 运算 符 
含义 说 明 

等 于 $a==$b; 如 果 $a 与 $b 的 值 相等 ， 结 果 为 TRUE， 否则 为 FALSE 

全 等 $a 一 =$b; 如 果 $a 与 $b 的 值 相等 ， 并 且 数 据 类 型 也 相同 ， 结 果 为 TRUE; 
否则 为 FALSE 

不 等 $a!=$b; 如 果 $a 与 $b 的 值 不 相等 ， 结 果 为 TRUE， 否则 为 FALSE 

非 全 等 $a!==$b; 如 果 $a 与 $b 的 值 不 相等 ， 或 者 数据 类 型 不 同 ， 结 果 为 TRUE; 
否则 为 FALSE 

小 于 $a<$b; 如 果 $a 的 值 小 于 $b 的 值 ， 结 果 为 TRUE; 否则 为 FALSE 

关乎 $a>$b; 如 果 $a 的 值 大 于 $b 的 值 ， 结 果 为 TRUE; 否则 为 FALSE 








小 于 等 于 $a<=$b; 如 果 $a 的 值 小 于 等 于 S$b 的 值 ， 结 果 为 TRUE， 否则 为 FALSE 
大 于 等 于 $a>=$b; 如 果 $a 的 值 大 于 等 于 Sb 的 值 ， 结 果 为 TRUE; 否则 为 FALSE 
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2.4.6 ”逻辑 运算 符 


逻辑 运算 符 对 布尔 类 型 数据 进行 相关 的 操作 ， 其 结果 为 布尔 类 型 结果 。 人 逻辑 运算 符 如 
表 2-9 所 示 。 
表 2-9 ”逻辑 运算 符 


说 明 
$a&&$b， 如 果 $a 与 $b 的 值 都 为 TRUE， 结 果 为 TRUE; 否则 为 FALSE 
$all$b; 如 果 $a 与 $b 的 值 中 至 少 有 一 个 为 TRUE， 结 果 为 TRUE; 否则 为 
FALSE 
!$a; 如 果 $a 的 值 为 TRUE， 结 果 为 FALSE; 否则 为 FALSE 
$a xor $b; 如 果 $a 与 $b 的 值 中 只 有 一 个 为 TRUE， 结 果 为 TRUE; 否则 为 
FALSE 














2.4.7 条 件 运 算 符 


条 件 运 算 符 的 语法 格式 如 下 : 
表达 式 1? 表 达 式 2 :表达 式 3 
条 件 表 达 式 的 运算 过 程 为 : 如果 表达 式 1 的 值 为 TRUE， 则 这 个 条 件 表达 式 的 值 为 表 
达 式 2 的 值 ， 如 果 表 达 式 1 的 值 为 FALSE， 则 这 个 表达 式 的 值 为 表达 式 3 的 值 。 条 件 运 算 
符 中 包含 3 个 操作 对 象 ， 因 而 也 称 条 件 运算 符 为 三 元 运算 符 。 例 如 : 
<?php 
$a=3; 
$b=4; 
$c=10; 
$d=15; 
echo $a>$b?$c:$d; 
区 
程序 运行 结果 为 : 
LS 


2.4.8 ”错误 抑制 运算 符 


在 编写 PHP 程序 时 ， 如 果 不 想 让 表达 式 产 生 的 错误 信息 显示 在 页 面 上 ， 可 以 将 错误 抑 
制 符 “@” 放 置 在 PHP 表达 式 之 前 。 这 样 既 可 以 避免 错误 信息 外 漏 、 造 成 系统 漏洞 ， 又 保 
证 了 页 面 的 整齐 和 美观 。 例 如 : 


<?php 
@print $a; //$a 未 曾 定 义 
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2.4.9 ”运算 符 的 优先 级 


所 谓 运 算 符 的 优先 级 ， 是 指 运算 符 运算 的 先后 次 序 。 一 个 复杂 的 PHP 表达 式 品 





往往 包 


含 多 种 运算 符 ， 表 达 式 运算 时 ， 优 先 级 高 的 运算 符 会 将 先 执行 ， 优 先 级 低 的 运算 符 后 执 
行 。PHP 中 各 类 运算 符 的 优先 级 排列 如 表 2-10 所 示 。 


表 2-10 运算 符 的 优先 级 














优先 级 别 运算 符 
1 and, xor, or 
= 二，+=，-=，*=，/=，%=， 二 
&&, | 
4 | ks 
5 &, 
6 +， 
村 hh 
8 i Sb 
各 ++， 
10 +，-( 取 负 )，! ，~ 
11 = 二 
12 <，<=，>，>= 
13 ?: 
14 -> 
15 二 


2.5 数据 类 型 的 转换 


在 编写 PHP 表达 式 的 时 候 ， 经 常会 出 现在 一 个 表达 式 中 包含 多 种 不 同类 型 数据 的 情 
况 ， 在 计算 这 些 数据 之 前 ， 必 须 将 它们 转换 为 同一 类 型 的 数据 。 这 就 涉及 PHP 数据 类 型 的 
转换 机 制 。PHP 数据 类 型 转换 包括 类 型 自动 转换 和 类 型 强制 转换 。 


25o 








类 型 














类 型 自动 转换 














预 处 理 器 根据 具体 应 | 
如 下 。 








环境 ， 将 变量 或 常量 转换 为 合适 的 数据 类 型 。 类 型 


(1) 布尔 类 型 数据 参与 算术 运算 。 
TRUE 将 被 转换 为 整数 1，FALSE 将 被 转换 为 整数 0。 例 如 : 


.So 























PHP 








动 转 换 是 指 在 定义 变量 或 常量 时 ， 不 需要 知道 变量 或 常量 的 数据 类 型 ， 上 


动 转换 








的 规则 


<?php 
$a=true; 
$b=false; 
echo 10+$a-$b; 
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// 相 当 于 计算 : 10+1-0 


(2) 浮 点 数 与 整数 进行 算术 运算 。 
先 将 整数 转换 为 浮 点 数 ， 再 进行 算术 运算 。 例 如 : 


<?php 
$a=10; 
$b=3.14; 
echo $a*$b; 


31.4 


(3) 字符 串 与 算术 运算 。 
先 截取 以 数字 开头 的 字符 串 
再 与 其 他 数字 进行 算术 运算 
<?php 
$a="10"; 
$b="3.14abc"; 
$c="cdel2"; 
echo $at+$b+$c; 


2> 
程序 运行 结果 为 : 
13.14 


(4) 数字 与 字符 串 连接 。 


整数 、 浮 点 数 都 将 被 转换 为 字符 串 ， 布 尔 型 TRUE 被 转换 为 字符 串 “1” 


， 直 到 遇 到 非 数 字 字 符 为 止 。 将 截取 的 子 字符 串 转换 为 数 
。 非 数字 开头 的 字符 串 会 被 转换 为 0。 例 如 : 


// 等 价 于 : 10+3.14+0 


FALSE 和 NULL 被 转换 为 空 字符 串 “”。 例 如 : 


<?php 
$a=10; 
$b=3.14; 
$c=TRUE; 
$d=FALSE; 
echo $a.$b.$c.$d; 
2% 


程序 运行 结果 为 : 


103.141 


pO le 放 
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(5) 其 他 数据 转换 为 布尔 型 值 。 





空 字 符 串 “”、 字 符 串 “0”、 整 数 0、 浮 点 数 0.0、NULL 以 及 空 数组 都 将 被 转换 为 
布尔 型 FALSE， 其 他 的 数据 都 将 被 转换 为 布尔 型 TRUE。 例 如 : 
<?php 


$a=0 && true; 

$b=0.0 && true; 
$c=NULL && true; 
$d="0" && true; 


echo var dump( $a),"<br/>"; // 输 出 : bool (false) 
echo var dump( $b),"<br/>"; // 输 出 : bool (false) 
echo var dump( $c),"<br/>"; // 输 出 : bool (false) 
echo var dump( $d),"<br/>"; // 输 出 : bool (false) 


2 


2.5.2 ”强制 类 型 转换 
强制 类 型 转换 是 指 程序 员 在 程序 中 将 变量 的 数据 类 型 强制 转换 为 指定 的 数据 类 型 。 强 
制 类 型 转换 常用 以 下 三 种 方法 。 
1. 在 变量 前 加 上 目标 数据 类 型 
PHP 中 允许 强制 转换 的 数据 类 型 如 表 2-11 所 示 。 
表 2-11 允许 强制 转换 的 数据 类 型 


转换 函数 转换 类 型 
(boolean),(bool) 转换 为 布尔 型 
string 转换 为 字符 串 类 型 
(integer),， (int) 转换 为 整 型 
float),(double), (real 转换 为 浮 点 型 
arra 转换 为 数组 
object 转换 为 对 象 
【实例 2-9】 强 制 类 型 转换 示例 。 
<?php 
$a=3.14; 
$b=(int) $a // 强 制 转换 为 整 型 数据 
$e=(f1loat)sas // 强 制 转 换 为 浮 点 型 数据 
$d=(string) $a; // 强 制 转换 为 字符 串 型 数据 


echo var dump ($b),"<br/>"; 

echo var dump ($c),"<br/>"; 

echo var dump ($d),"<br/>"; 
芭 


程序 运行 结果 如 图 2-8 所 示 。 
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int (3) 
float(3.14) 
string(4) “3.14” 





2-8 实例 2-9 的 运行 结果 
2. 使 用 函数 强制 转换 
PHP 中 可 以 强制 转换 数据 类 型 的 函数 如 表 2-12 所 示 。 
表 2-12 ”强制 类 型 转换 函数 
返回 变量 或 常量 var 的 整数 值 
返回 变量 或 常量 var 的 浮 点 数值 





返回 变量 或 常量 var 的 字符 趾 值 


【实例 2-10】 强 制 类 型 转换 函数 示例 。 


<?php 
$a="3.16abc"; 
$b=intval ($a); 
$c=floatval ($a); 
$d=strval ($a); 
echo var dump ($b),"<br/>"; 
echo var dump ($c),"<br/>"; 
echo var dump ($d),"<br/>"; 
> 


程序 运行 结果 如 图 2-9 所 示 。 


© DB localhost 


int (3) 
float(3.16) 
string(7)“3.16abc” 





图 2-9 实例 2-10 的 运行 结果 
3. 使 用 settype() 函 数 强制 转换 数据 类 型 
函数 settype0 的 语法 格式 如 下 : 
bool settype (mixed var,string type) 


函数 参数 说 明 如 表 2-13 所 示 。 
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表 2-13 ”函数 settype() 的 参数 说 明 


说 明 





变量 的 名 称 
将 变量 var 转换 为 指定 的 数据 类 型 ， 包 括 bool、int、float、string、array、object、NULL 
函数 功能 : 设置 变量 var 的 数据 类 型 为 type 数据 类 型 。 若 函数 执行 成 功 ， 返 回 
TRUE， 否 则 返回 FALSE。 
【实例 2-11】 使 用 函数 settypeO 强 制 转换 数据 类 型 。 











<?php 
S$a="3.16abc"7 

settype ($a, "bool"); // 将 $a 转换 为 布尔 型 
echo var dump ($a) ,"<br/>"; 
settype ($a, "int"); // 将 $a 转换 为 整 型 
echo var dump ($a) ,"<br/>"; 
settype ($a, "string"); // 将 $a 转换 为 字符 串 型 
echo var dump ($a) ,"<br/>"; 
settype ($a, "array"); // 将 $a 转换 为 数组 类 型 
echo var dump ($a) ,"<br/>"; 
settype ($a, "NULL"); // 将 $a 转换 为 NULL 
echo var dump ($a) ,"<br/>"; 
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程序 运行 结果 如 图 2-10 所 示 。 


localhost /erasple_2-1 
所 © localhost 


bool (true) 

int (1) 

string(1) “1” 

array(1) { [0]=> string(1) “1” ) 
NULL 





图 2-10 实例 2-11 的 运行 结果 
本 章 小 结 


本 章 详细 介绍 了 PHP 中 的 常量 、 变 量 、 数 据 类 型 、 运 算 符 和 表达 式 ， 以 及 数据 类 型 转 
换 的 方法 和 应 用 。 

PHP 的 常量 分 为 自 定义 常量 和 预定 义 常 量 ， 自 定义 常量 必须 使 用 define() 函 数 来 定义 。 

PHP 的 数据 类 型 分 为 标量 数据 类 型 、 复 合 数据 类 型 和 特殊 数据 类 型 。 

@ 标量 数据 类 型 : 布尔 型 (boolean)、 字 符 串 型 (string)、 整 型 (integer) 和 浮 点 型 

(float)。 

@ ”复合 数据 类 型 数组 (arrry) 和 对 象 (object)。 

@ ”特殊 数据 类 型 ,资源 (resource) 和 空 值 (null)。 

PHP 的 运算 符 包括 算术 运算 符 、 字 符 串 运算 符 、 赋 值 运算 符 、 递 增 或 递减 运算 符 、 比 
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较 运 算 符 、 逻 辑 运算 符 、 条 件 运 算 符 、 错 误 抑 制 运算 符 、 位 运算 符 等 。 
PHP 数据 类 型 转换 包括 类 型 自动 转换 和 类 型 强制 转换 。 
@ ”类 型 自动 转换 是 指 PHP 根据 程序 的 需要 ， 自 行将 变量 或 常量 的 值 转换 为 合适 的 数 
据 类 型 。 
@ ”类 型 强制 转换 是 指 用 户 强 行将 变量 或 常量 的 值 转换 为 指定 的 数据 类 型 。 


习 题 


1. 分 析 下 面 程序 中 变量 的 数据 类 型 及 程序 的 运行 结果 。 


<?php 
$a="123.45bac"; 
$b=10; 
$c=true; 
echo $a-$b+$c; 


2. 已 知 圆 的 半径 为 20， 计 算 并 输出 圆 的 面积 。 
3. 梯形 的 上 边 、 下 边 、 高 分 别 为 10、20 和 6， 计 算 并 输出 梯形 的 面积 。 
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本 章 要 点 
@ ”选择 结构 
@ ”循环 结构 
”包含 语句 
学 习 目 标 


@ ”熟练 掌握 选择 结构 、 循 环 结构 及 包含 语句 


3.1 选择 结构 


选择 结构 又 称 为 分 支 结构 ， 就 是 根据 条 件 进行 逻辑 判断 ， 以 决定 当前 程序 的 走向 ， 从 





而 得 到 不 同 的 结果 。 
3.1.1 if 语 句 


让 语句 的 语法 格式 如 下 : 
if (条 件 表达 式 ) { 
语句 块 
人 
说 明 : 当 “ 语 句 块 ”为 一 条 语句 时 ， 可 省 略 “{}”。 
功能 : 当 “ 条 件 表达 式 ” 的 值 为 TRUE 时 ， 执 行 语句 块 ， 否 则 执行 站 语句 后 面 的 语句 。 
让 语句 的 流程 图 如 图 3-1 所 示 。 





3-1 if 语句 的 流程 图 


【实例 3-1】 站 语句 示例 。 


<?php 
header ("Content-Type:text/html;charset=gb2312"); 
$a=9; 
$b=8; 
if($a>$p){ 
echo "a 大 于 b"; 
} 
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该 段 程序 的 功能 为 判断 变量 a 是 否 大 于 变量 b， 如 果 成 立 ， 则 输出 “a 大 于 b”。 
3.1.2 if...else 语句 

让 ...else 语句 是 一 种 二 分 支 选择 语句 。else 的 功能 就 是 当 条 件 表达 式 的 值 为 FALSE 时 
执行 其 他 的 语句 。if...else 语句 的 语法 格式 如 下 : 


if (条 件 表达 式 ) { 
语句 块 1 


语句 块 2 





说 明 : 当 “ 语 句 块 1” 或 “语句 块 2” 为 单条 语句 时 ， 可 省 略 “{}”。 

功能 : 当 “ 条 件 表达 式 ” 的 值 为 TRUE 时 ， 执 行 “ 语 句 块 1”， 否 则 将 执行 “语句 
块 2”。 

让 ...else 语句 的 流程 图 如 图 3-2 所 示 。 





3-2 ”if...else 语句 的 流程 图 
【实例 3-2】if...else 语句 示例 。 


<?php 
header ("Content-Type:text/html;charset=gb2312"); 
$a=9; 
if ($a%2==0){ 
echo "a 是 偶数 "; 
}elsef{ 
echo "a 是 奇数 "; 
Ek 
?> 


该 段 程序 的 功能 就 是 判断 变量 a 的 奇偶 性 。 若 变量 a 能 够 整除 2， 则 为 偶数 ， 否 则 为 
奇数 。 

在 同时 判断 多 个 条 件 的 时 候 ，PHP 还 提供 了 elseif 语句 来 扩充 需求 。elseif 语句 被 放置 
在 让 和 else 之 间 ， 以 满足 多 条 件 同 时 判断 的 需求 。 

【实例 3-3】 根 据 输入 的 百分制 成 绩 ， 输 出 对 应 的 等 级 制 。 
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<?php 


header ("Content-Type:text/html;charset=gb2312"); 


$score=80; 


if($score>=90 && $score<=100){ 


echo "优秀 !"; 
}elseif ($score>=80){ 
echo "良好 ! "; 
}elseif ($score>=70)1{ 
echo "中 等 !"; 
}elseif ($score>=60)1{ 
echo "及 格 !"; 
}elseif ($score>=0){ 
echo "不 及 格 !"; 
} 


2 
程序 运行 结果 为 : 
良好 ! 


3.1.3 ”switch 语句 


站 语句 只 有 两 个 分 支 可 供 选 择 ， 如 果 遇 到 多 分 支 的 选择 ， 虽 然 可 以 使 用 嵌 套 的 让 语句 
来 处 理 ， 但 如 果 分 支 较 多 ， 会 造成 嵌 套 的 站 层 数 过 多 ， 程 序 过 于 元 长 而 且 难 以 修改 。 





switch 语句 是 多 分 支 选 择 语句 ， 利 
如 下 : 


switch (表达 式 ) { 
case 值 1: 
语句 块 1 
break; 
case 值 2: 
语句 块 2 


break; 


default: 
语句 块 n 
} 














它 可 以 直接 处 理 多 分 支 选 择 。switch 语句 的 语法 格式 


功能 : 执行 switch 语句 时 ， 先 计算 “表达 式 ” 的 值 ， 然 后 顺序 测试 该 值 与 哪 一 个 case 
子 句 中 的 “ 值 ” 相 匹配 。 一 旦 找到 ， 则 执行 该 case 分 支 的 语句 块 ， 直 到 遇 到 break 语句 才 
跳出 当前 的 switch 语句 ， 如 果 没 有 找到 相 匹配 的 值 ， 则 执行 default 分 支 的 语句 块 (default 





为 可 选 部 分 )。 


【实例 3-4】 根 据 水 果 的 英文 单词 ， 输 出 对 应 的 中 文 水 果 名 。 


<?php 


header ("Content-Type:text/html;charset=gb2312"); 


$fruit="banana™; 
Switch ($fruit)t{ 


.ao 
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Case "apple": 
echo "苹果 "; 
break; 

Case "banana": 
echo "香蕉 "; 
break; 

Case "orange": 
echo "橘子 "7 
break; 

case "pearn : 


echo "梨子 !"; 


break; 
default: 
"其 他 水 果 ! "; 
下 
> 
程序 运行 结果 为 : 
香 燕 


3.2 循环 结构 


所 谓 循环 ， 是 指 对 某 一 个 程序 段 重 复 执 行 若干 次 ， 被 重复 执行 的 程序 部 分 称 为 循环 体 。 
在 PHP 中 ， 共 有 三 种 循环 结构 语句 ， while 循环 语句 、do...while 循环 语句 和 for 循环 语句 。 


3.2.1 while 语句 


while 循环 语句 的 语法 格式 如 下 : 
while (条 件 表达 式 ) { 
语句 块 
} 
功能 : 当 “ 条 件 表达 式 ” 的 值 为 TRUE 时 ， 程 序 将 执行 循环 体内 的 “语句 块 ”， 直 到 
“条 件 表达 式 ” 的 值 为 FALSE 的 时 候 才 跳出 循环 ， 执 行 while 循环 后 面 的 语句 。while 循 
环 语 句 的 流程 图 ， 如 图 3-3 所 示 。 





3-3 ”while 循环 语句 的 流程 图 
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说 明 : 

@ ”如 果 条 件 表达 式 的 值 始 终 为 TRUE， 则 循环 体内 的 “语句 块 ” 将 一 直 被 执行 下 
去 ， 这 就 构成 了 “ 死 循 环 ”。 所 以 在 循环 体 的 语句 块 中 ， 必 须要 有 改变 条 件 表达 
式 的 语句 ， 使 循环 能 够 正常 结束 。 

@ ”while 循环 可 以 嵌 套 ， 但 不 允许 出 现 交叉 。 

【实例 3-5】 小 明 今 年 12 岁 ， 他 父亲 比 他 大 30 岁 ， 问 经 过 多 少年 后 ， 父 亲 的 年 龄 是 

小 明年 龄 的 2 倍 ， 那 时 父子 的 年 龄 各 为 多 少 ? 

<?php 
header ("Content-Type:text/html;charset=gb2312"); 
$age=12; 
while ($age*2<>$age+30){ 

$age=$age+1; 





} 

echo "经 过 " . ($age-12) ." 年 后 ， 小 明 父 亲 的 年 龄 是 小 明年 龄 的 2 倍 ! </br>"; 
echo "小 明 的 年 龄 为 : " .$age."</br>"; 

echo "小 明 父亲 的 年 龄 为 :". (30+$age); 


?> 


运行 结果 如 图 3-4 所 示 。 


D localhost/example_3-6. php YY 


经 过 18 年 后 ， 小 明 父亲 的 年 龄 是 小 明年 龄 的 2 倍 ! 
小 明 的 年 龄 为 ，30 
小 明 父亲 的 年 龄 为 :60 





3-4 “实例 3-5 运行 结果 
3.2.2 do...while 语句 


do...while 循环 语句 的 语法 格式 如 下 : 
dof 
语句 块 

}while (条 件 表达 式 ) ; 

功能 : 程序 先 执 行 循 环 体 中 的 “语句 块 ”， 然 后 再 判断 “条 件 表 达 式 ”的 值 ， 如 果 值 
为 TRUE， 则 继续 执行 循环 体 中 的 “语句 块 ”， 直 到 “条 件 表达 式 ” 的 值 为 FALSE 时 才 跳 
出 循环 ， 执 行 do...while 之 后 的 语句 。do...while 循环 语句 的 流程 图 如 图 3-5 所 示 。 

说 明 : do...while 循环 和 while 循环 非常 相似 ， 但 do...while 循环 对 条 件 的 检测 是 在 执 
行 完 循环 体 后 才 进行 ， 故 do...while 循环 语句 中 的 “语句 块 ”不 管 “ 条 件 表达 式 ” 成 立 与 
否 ， 至 少 要 被 执行 一 次 。 


.AN 
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图 3-5 ”do...while 循环 语句 的 流程 图 


【实例 3-6】 用 do...while 循环 结构 实现 实例 3-5。 


<?php 
header ("Content-Type:text/html;charset=gb2312"); 
$age=12; 
dof 
$age=$aget+l; 
}while ($age*2<>$age+30); 
echo "经 过 " . ($age-12) ." 年 后 ， 小 明 父 亲 的 年 龄 是 小 明年 龄 的 2 倍 ! </br>"; 
echo "小 明 的 年 龄 为 : " .$age."</br>"; 
echo "小 明 父亲 的 年 龄 为 :". (30+$age); 
证 


3.2.3 for 循环 语句 


for 循环 语句 多 用 于 循环 次 数 已 知 的 程序 结构 ， 语 法 格式 如 下 : 

for (表达 式 1; 表 达 式 2; 表达 式 3) { 
语句 块 

} 

说 明 : 

@ “表达 式 1” 用 于 为 循环 变量 赋 初 值 。 也 人 允许 在 for 循环 之 外 为 循环 变量 赋 初 值 ， 
此 时 “表达 式 1” 可 省 略 。 

@ “表达 式 2” 为 循环 条 件 ， 若 其 值 为 TRUE， 则 执行 循环 体 中 的 “语句 块 ”; 若 
其 值 为 FALSE， 则 跳出 for 循环 。 

@ “表达 式 3” 用 于 改变 循环 变量 的 值 。 

@ 3 个 表达 式 都 是 任 选 项 ， 都 可 以 省 略 ， 但 分 号 不 能 省 略 。 

for 循环 语句 的 流程 图 如 图 3-6 所 示 。 


(2. 
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图 3-6 for 循环 语句 的 流程 图 
【实例 3-7】 利 用 for 循环 语句 计算 1+2+3+…+100 的 值 。 
<?php 
header ("Content-Type:text/html;charset=gb2312"); 
$sum=0; 
for ($i=1;$i<=100;$i++) { 
$sum=$sum+$i; 
} 
echo "1+2+3+…+100 的 和 : ".$sum; 


2> 
程序 运行 结果 如 图 3-7 所 示 。 


国 1ocalhost/exasple 3-8 x 


i © |D localhost/example_ 


1+2+3+…+100 的 和 :，5050 





图 3-7 实例 3-7 的 运行 结果 


3.3 跳 转 语句 


在 程序 运行 中 ， 有 时 需要 在 结构 中 改变 程序 的 执行 语句 ， 比 如 在 switch 语句 中 ， 使 用 
break 语句 。 为 了 更 灵活 地 控制 程序 执行 ，PHP 提供 了 continue 和 break 语句 ， 用 来 实现 程 
序 的 跳 转 执行 。 








3.3.1 continue 语句 


continue 语句 的 作用 就 是 跳 过 本 次 循环 中 剩余 的 语句 而 执行 下 一 次 循环 。continue 语句 
.AN 
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通常 与 下 语句 结合 在 一 起 ， 应 用 在 for 循环 、while 循环 以 及 do...while 循环 等 循环 语句 中 。 
【实例 3-8】 求 1 一 100 的 偶数 之 和 。 


<?php 
header ("Content-Type:text/html;charset=gb2312"); 
$sum=0; 
for ($i=1; $i<=100; $i++) { 
if ($i%2<>0){ 
continue; 
} 
$sum=$sum+$i; 
} 
echo "1-100 的 偶数 之 和 为 :" ,$sum; 


程序 运行 结果 如 图 3-8 所 示 。 


国 1ocalhost/exa=p1s_ 3-3 ，x We 
外 名 口 localhost/example_3-9.php 5 


1-100 的 偶数 之 和 为 ，2550 





3-8 ”实例 3-8 的 运行 结果 
3.3.2 ”break 语句 


break 语句 在 switch 语句 中 使 用 时 ， 可 以 使 程序 跳出 当前 的 switch 语句 ， 当 break 语句 
用 于 for 循环 、while 循环 以 及 do...while 循环 语句 中 时 ， 可 以 使 程序 终止 于 break 所 在 层 
的 循环 ， 即 跳出 当前 循环 ， 转 而 执行 当前 循环 之 后 的 语句 。 
【实例 3-9】 判 断 一 个 整数 是 否 为 素数 。 
所 谓 素数 即 质数 ， 就 是 只 能 被 1 和 自身 整除 的 整数 。 判 断 整数 n 是 否 为 素数 ， 只 需 判 
断 n 能 和 否 被 从 2 到 (int)sqrt(n) 之 间 的 整数 整除 即 可 。 若 n 能 被 其 中 的 一 个 整数 整除 ， 则 n 不 
是 素数 ， 否 则 n 就 是 素数 。 


<?php 
header ("Content-Type:text/html;charset=gb2312"); 
$n=1321; 
$k=(int) sqrt ($n); 
for ($i=2; $i<=$k; $i++) { 
if ($n%$i==0) break; 
if ($i>$k){ 
echo $n, "是 素数 !1"; 
}elsef 
echo $n, "不 是 素数 !"; 
} 
2 


(45. 
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程序 运行 结果 如 图 3-9 所 示 。 


€ 3 © |D localhost/exanple_ 3-10.php 安 


1321 是 素数 ! 





3-9 ”实例 3-9 运行 结果 


3.4 包含 语句 


PHP 中 有 4 个 包含 文件 的 语句 ， 即 由 函数 include()、include_once()、require() 和 
require_once() 所 构成 的 语句 。 

include( 或 require) 语 句 会 获取 指定 文件 中 存在 的 所 有 文本 、 代 码 及 标记 ， 并 复制 到 使 
用 include 语句 的 文件 中 。 如 果 在 网 站 的 多 个 页 面 上 引用 相同 的 PHP、HTML 或 文本 ， 
使 用 包含 文件 可 以 避免 重复 编程 ， 提 高 编程 效率 。 这 样 可 以 为 所 有 页 面 创 建 标准 页 头 、 页 
脚 或 者 菜单 文件 ， 当 页 头 、 页 脚 或 菜单 文件 需要 更 新 时 ， 只 需要 更 新 所 包含 的 文件 即 可 。 





3.4.1 include() 语 句 


include 的 语法 格式 如 下 : 


include (string resource) 


说 明 :，include0 语 句 将 一 个 资源 文件 载 入 当前 PHP 程序 中 ， 其 效果 和 将 该 文件 的 内 容 
复制 到 include0 出 现 的 地 方 一 样 。 若 没有 找到 资源 文件 resource，include0) 语 句 返 回 
FALSE; 若 找到 资源 文件 resource， 且 resource 没有 返回 值 ， 则 include0 返 回 整数 1， 和 否则 
返回 资源 文件 resource 的 返回 值 。 

【实例 3-10】include0 语 句 应 用 示例 。 
创建 PHP 程序 文件 footer.php， 程 序 代 码 如 下 : 
<?php 
header ("Content-Type:text/html;charset=gb2312"); 
echo "<p>Copyright 2014-" . date ("Y") ."</p>"; 








> 


创建 程序 文件 includephp， 在 include.php 程序 中 包含 footerphp 程序 文件 。 程 序 代 码 
如 下 : 


<html> 

<body> 

<meta http-equiv="Content-Type" content="text/html; charset=gb2312" /> 
<h1> 欢 迎 访问 我 们 的 首页 ! </h1> 

<p> 一 段 文本 。</p> 

<p> 一 段 文 本 。</p> 
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<?php 
include ("footer.php"); 
2 
</body> 
</html> 


程序 运行 结果 如 图 3-10 所 示 。 


国 10calhost/inciuse. php x We 
€ © BD localhost/includ 


欢迎 访问 我 们 的 首页 ! 


| 号 


一 段 文本 。 
一 段 文本 。 
Copyright 2014-2016 





3-10 ”实例 3-10 的 运行 结果 
3.4.2 ”require() 语 句 


require() 语 句 与 include() 语 句 在 语法 格式 及 功能 上 基本 相同 。require0 语 句 通常 放 在 
PHP 程序 的 最 前 面 ，PHP 程序 在 执行 前 ， 就 会 先 读 入 require0 语 句 引 入 的 文件 ， 使 它 变 
成 PHP 程序 的 一 部 分 。 

require() 语 句 与 include() 语 句 的 区 别 在 于 : 对 include() 来 说 ， 在 执行 文件 时 每 次 都 要 进 
行 读 取 和 评估 ;而 对 于 require() 来 说 ， 文 件 只 处 理 一 次 ( 即 文件 内 容 蔡 换 require() 语 句 )。 这 
就 意味 着 如 果 执 行 多 次 代码 ， 则 使 用 require0 的 效率 比较 高 ， 如 果 每 次 执行 代码 时 是 读 取 
不 同 的 文件 ， 则 适合 使 用 include0 语 句 。 

【实例 3-11】require0 语 句 应 用 示例 。 
创建 程序 菜单 文件 menu.php， 程 序 代 码 如 下 : 
<?php 
header ("Content-Type:text/html;charset=gb2312"); 
echo "<a href=index.php> 首 页 </a> - <a href=html_cource.php>HTML 教程 </a> 
-<a href=css_cource.php>CSS 教程 </a> -<a href=js_cource.php>JavaScript 教 


程 </a> -<a href=php_cource.php>PHP 教程 </a>"; 
ES 


创建 程序 文件 require php， 在 该 程序 中 通过 require0 语 句 包含 menu.php 程序 文件 。 程 
序 代码 如 下 : 


<html> 
<body> 
<?php 

require ("menu.php"); 
> 
<h1> 欢 迎 访问 我 的 首页 ! </h1> 
<p> 一 段 文 字 </p> 


.AT 
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<p> 一 段 文字 </p> 
</body> 
</html> 


程序 运行 后 ， 在 浏览 器 的 地 址 栏 输入 http:Wlocalhostrequire php， 则 运行 结果 如 图 3-11 
所 示 。 


国 1ocalhost/rennirs. she x We 
€ © BD localhost/require. ph 


首页 - HUIL 教程 -CSS 教程 -TavaScript 教程 -PHP 教程 


欢迎 访问 我 的 首页 ! 





3-11 实例 3-11 的 运行 结果 


如 果 requireO 语 句 引 用 的 资源 文件 存在 错误 ， 那 么 程序 就 会 中 断 执行 ， 并 显示 致命 错 
误 ， 如 果 includeO 语 句 引用 的 资源 文件 存在 错误 ， 则 程序 不 会 中 断 ， 而 是 继续 执行 ， 并 显 
示 一 个 警告 错误 。 

【实例 3-12】 分 别 运行 程序 文件 test-include.php 和 testrequire php。 程 序 中 的 程序 文 
件 test-nothing.php 不 存在 。 

test-include.php 程序 代码 如 下 : 

<?php 


include ("test-nothing.php"); 
echo "abc"; 
Epa 


test-require.php 程序 代码 如 下 : 
<?php 


require ("test-nothing.php"); 
echo "abc"; 
Rs 


在 浏览 器 的 地 址 栏 输 入 http:Wlocalhosttest-include php， 运 行 结果 如 图 3-12 所 示 。 


eio] 





电 训 三 


Warning: include(test-nothing. php): failed to open stream: No such file 
or directory in C:\xampp\htdocs\test-include.php on line 2 


Warning: include(): Failed opening ’ test-nothing. php’ for inclusion 
(include_path=' . ;C:\xampp\php\PEAR’ ) in C:\xampp\htdocs\test— 
include. php on line 2 

abc 


图 3-12 test-include.php 程序 文件 的 运行 结果 


(48). 


第 3 章 PHP 流程 控制 语句 属 I 有 


在 浏览 器 的 地 址 栏 中 输入 http://localhost/test- require php， 运 行 结果 如 图 3-13 所 示 。 


量 | 3 


€ @ |D localhost/test-require. php 呈 交 了 鞍 


Warning: require(test-nothing. php): failed to open stream: No such file 
or directory in C:\xampp\htdocs\test-require.php on line 2 


Fatal error: require(): Failed opening required ' test-nothing. php’ 
(include_path=’ . ;C:\xampp\php\PEAR’ ) in C:\xampp\htdocs\test— 
require. php on line 2 





3-13 ”程序 文件 test-require.php 的 运行 结果 
3.4.3 include_once( ) 语 句 


include_once() 语 句 是 对 include() 语 句 的 延伸 ， 它 的 作用 和 include0 语 句 几乎 一 样 。 唯 
一 的 区 别 就 是 include_once0 语 句 会 在 导入 文件 前 检测 该 文件 是 否 在 该 页 面 的 其 他 地 方 已 被 
导入 。 如 果 有 的 话 ， 就 不 会 重复 导入 该 文件 。 
【实例 3-13】include_once0) 语 句 示例 。 
创建 header.php 程序 文件 ， 程 序 代 码 如 下 : 
<?php 
header ("Content-Type:text/html;charset=gb2312"); 
echo" 当 前 日 期 : "，date("Y-m-d"); 
?> 


创建 程序 文件 example_3-13.php， 程 序 代 码 如 下 : 


<?php 
include_once ("header.php"); 
> 


程序 运行 结果 如 图 3-14 所 示 。 


园 1ecalhost /i php 


€ © BD localhost/11.php 


当前 日 期 ，2016-03-28 





图 3-14 ”实例 3-13 的 运行 结果 
3.4.4 ”require_once( ) 语 句 


require_once() 语 句 是 对 require() 语 句 的 延伸 ， 它 的 功能 和 require0) 语 句 几乎 一 样 。 区 别 
在 于 require_once() 语 句 会 先 检查 要 导入 的 文件 是 否 已 经 在 本 程序 的 其 他 地 方 被 导入 过 ， 如 
果 有 ， 则 不 会 再 次 重复 调用 该 文件 。 如 果 在 同一 程序 中 使 用 require_once() 语 句 两 次 调用 同 
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一 文件 ， 那 么 第 一 次 调用 时 会 有 输出 结果 ， 第 二 次 调用 则 不 会 有 输出 结果 。 
【实例 3-14】require_onceO 语 句 应 用 示例 。 
<?php 
Fequire_once ("header .php"); 
echo "Hello PHP!"; 


require _once ("header.php"); 
> 


程序 运行 结果 如 图 3-15 所 示 。 


园 1ocalhost/i1. php x 


所 © | 口 localhost/11. php 


当前 日 期 ，2016-03-28 
Hello PHP! 





3-15 ”实例 3-14 的 运行 结果 
3.5 ”综合 实 训 案例 


本 节 主 要 介绍 利用 循环 结构 语句 制作 九 九 乘法 表 的 方法 。 
1. 分 析 


设置 一 个 HTML 表格 table， 在 表格 中 的 每 一 个 单元 格 <tdt> 中 显示 一 个 乘法 表达 式 。 

设置 变量 : $i 表示 被 乘 数 ， 取 值 范围 为 1 一 9;， $j 表示 第 i 行 中 与 $i 相 乘 的 数 ， 取 值 范 
围 为 Si 一 9。 

九 九 乘法 表 如 图 3-16 所 示 。 


加 1-calhozt/jj php x 

€ 3 CC | localhost/jj.php 

九 九 乘法 表 

1x1=1 1x2=2 1xX 3=3 1x6=6 1 xX?7=7 
2x 2=4 2x3=6 2x4-8 2x7=14_ 2x8=16 
3X 3=9 Jl3x5=15 3xX8=24 ||3x9=27 
4X4=16 4X 6=24 4X 9=36 
I5X 5=25 I5X7=35 
[6X 6=36 I6X 8=48 
TX7=49 TX 9=63 
8Xx 8=64 
I9x 9=81 
























































































































































3-16 ” 九 九 乘法 表 


2. 程序 代码 
编程 实现 创建 PHP 程序 文件 计 php， 程 序 代码 如 下 : 
/so0\. 
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<?php 
header ("Content-Type:text/html;charset=gb2312"); 
echo " 九 九 乘法 表 "; 


echo "<table border=1>"; // 创 建 HTML 表格 
for ($i=17$Si<=97$Si++) // 从 1 乘 到 9 
{ 
echo "<tr>"; // 显 示 每 一 行 
for ($j=$i;$j<=9;$j++) // 计 算 第 i 行 的 乘法 运算 
echo "<td>"; // 显 示 表格 中 的 单元 格 


echo $i."x".$j."=".$i*$j."&nbsp;&nbsp;"; // 在 单元 格 中 显示 结果 
echo "</td>"; 
} 
echo "</tr>"; // 每 一 行 输出 结束 时 换行 
了 
echo "</table>"; 
> 


本 章 小 结 


本 章 详细 介绍 了 选择 结构 、 循 环 结构 以 及 包含 语句 。 选 择 结构 包含 这、 让 ..else 和 
让 ..elseif...else 语句 ， 循 环 结构 包含 while 循环 语句 、do...while 循环 语句 和 for 循环 语句 ， 
包含 语句 包含 include()、require()、include_once() 与 require_once() 语 句 。 


习 是 


1. 编程 求 1 ~ 100 之 间 的 奇数 之 和 。 
2. 编程 画 出 以 下 图 形 。 
来 
米 米 米 
米 米 米 米 米 
米 米 米 米 米 米 米 
米 米 米 米 米 米 米 米 米 
3. 找 出 100 一 1000 之 间 的 所 有 素数 。 
4. 找 出 所 有 的 水 仙 花 数 。 水 仙 花 就 是 一 个 三 位 的 整数 ， 其 个 位 、 十 位 、 百 位 的 立方 和 
等 于 原来 的 数 ， 比 如 153=13+53+33。 
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本 章 要 点 
@。 自 定义 函数 的 定义 与 调用 


® 9 定义 函数 参数 的 传递 
@ 量 的 作用 域 及 生存 周期 


学 习 目 标 

@ 掌握 PHP 自 定义 函数 的 定义 与 调用 

@ 掌握 PHP 自 定义 函数 的 参数 传递 方法 

@ 掌握 PHP 局 部 变量 、 全 局 变量 的 应 用 方法 


4.1 自 定 义 函 数 


在 编程 过 程 中 ， 若 有 一 段 代 码 需要 反复 调用 ， 就 可 以 考虑 把 它 写 成 函数 ， 在 需要 的 时 
候 就 可 以 调用 它 。 编 写 函 数 的 目的 就 是 为 了 简化 编程 ， 优 化 代码 ， 提 高 效率 ， 便 于 维护 ， 
避免 重复 开发 。 


4.1.1 自 定义 函数 的 定义 与 调用 
1. 函数 的 定义 
在 PHP 中 自 定义 函数 的 语法 格式 如 下 : 


function fun name ($arg 1,$arg 2,..,$arg_n) 


函数 体 
return 返回 值 ; 














面 对 自 定义 函数 的 语法 格式 做 说 明 。 
function: 声明 自 定义 函数 时 必须 使 用 的 关键 字 。 
fun_name: 自 定义 函数 名 称 。 其 命名 遵循 变量 命名 规则 ， 但 不 能 以 “$” 开 头 。 
$arg_1,.…,$arg_n: 函数 的 参数 。 多 个 参数 之 间 以 逗号 隔 开 ， 参 数 的 类 型 可 以 不 指 
定 。 
@ 函数 体 : 函数 被 调用 时 执行 的 代码 。 
@ retum: 返回 函数 的 执行 结果 ， 并 结束 函数 的 运行 。 
2. 自 定 义 函 数 的 调用 
调用 自 定义 函数 时 ， 一 定 要 先 声明 自 定义 函数 ， 然 后 才 可 以 调用 。 调 用 自 定 义 函 数 的 
语法 格式 如 下 : 
fun name (value 1,value 2,...,value n) 
下 面 对 调 用 自 定义 函数 的 有 选项 做 说 明 。 
@ fun name: 调用 自 定义 函数 的 函数 名 ， 函 数 名 大 小 写 不 敏感 。 








eee = 
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@ value 1...value_ n: 传递 给 函数 的 参数 值 。 参 数 的 个 数 、 顺 序 要 与 函数 定义 时 的 个 


数 、 顺 序 保持 一 致 。 
【实例 4-1】 定 义 函 数 fun( )， 其 功能 是 计算 传 入 参数 的 阶乘 。 
<?php 


function fun(Sn) 
{ 
$s=1; 
for ($i=1; $i<=$n; $i++) 
$sS*=$i; 
return $s; 
: 
echo fun(5); 
区 


结果 为 : 120 
4.1.2 在 函数 间 传 递 参数 


在 调用 函数 时 ， 需 要 向 函数 传递 参数 ， 被 传 入 的 参数 称 为 实际 参数 (简称 实 参 )， 而 函 
数 定义 的 参数 称 为 形式 参数 (简称 形 参 )。 自 定义 函数 的 参数 传递 方式 有 三 种 : 按 值 传递 、 
按 引 用 传递 和 可 选 参数 。 


1. 值 传递 方式 


按 值 传递 是 将 实 参 的 值 “ 复 制 ” 到 对 应 的 形 参 ， 在 函数 内 部 针对 形 参 进行 操作 ， 对 形 
参 操 作 的 结果 不 会 影响 到 实 参 原来 的 值 ， 即 函数 返回 后 ， 实 参 的 值 不 发 生变 化 。 
【实例 4-2】 按 值 传递 函数 参数 示例 。 


<?php 
header ("Content-Type:text/html;charset=gb2312"); 
function fun (Snumber) // 定 义 函 数 ， 按 值 传递 参数 的 值 
{ 
$number=$number+10; 
echo $number; // 函 数 内 输出 形 参 的 值 
} 
$n=20; 
echo "传递 前 : ", $n，"<br/>"; // 变 量 n 传递 前 的 值 
echo "函数 中 : ", fun (Sn) ，"<br/>"; // 将 $n 的 值 传递 给 形 参 Snumber 
echo "传递 后 : ", Sn， "<br/>"; // 实 参 的 值 没 有 发 生变 化 


人 


程序 运行 结果 如 图 4-1 所 示 。 
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4-1 按 值 传递 方式 的 运行 结果 


通过 本 实例 的 运行 结果 可 以 看 出 ， 函 数 的 参数 在 使 用 按 值 传递 方式 时 ， 函 数 内 部 只 针 
对 形 参 进行 操作 ， 不 改变 实 参 的 值 。 
程序 运行 过 程 中 的 内 存 分 配 如 图 4-2 所 示 。 


(a) 函数 调用 时 (b) 函数 调用 中 (c) 函数 调用 后 
图 4-2 ” 按 值 传递 时 ， 参 数 在 内 存 中 的 动态 分 配 
[ 忆 提示 : ， 在 使 用 按 值 传递 方式 时 ， 在 函数 fun( ) 被 调用 的 时 候 ， 系 统 为 参数 Snumber 
分 配 了 内 存 空间 ， 但 系统 没有 为 参数 值 分 配 新 的 内 存 空间 。 当 参数 $number 


的 值 发 生变 化 时 ， 系 统 为 Snumber 的 值 分 配 新 的 内 存 空间 。 当 函数 fun( ) 运 
行 完毕 结束 调用 时 ， 系 统 回收 函数 调用 期 间 分 配 的 所 有 内 存 空间 。 


2. 引用 传递 方式 


按 引 用 传递 就 是 将 实 参 的 内 存 地 址 传递 给 对 应 的 形 参 。 此 时 ， 在 函数 内 部 的 操作 都 会 
影响 到 实 参 的 值 ， 返 回 后 ， 实 参 的 值 会 发 生变 化 。 使 用 引用 传递 方式 ， 要 在 函数 的 参数 前 


加 一 个 “及 ”符号 。 
【实例 4-3】 按 引用 传递 函数 参数 示例 。 
<?php 
header ("Content-Type:text/html;charset=gb2312"); 
function fun(&Snumber) // 定 义 函 数 ， 按 引用 方式 传递 参数 的 值 
{ 
$number=$number+10; 
echo $number; // 函 数 内 输出 形 参 的 值 
} 
$n=20; 
echo "传递 前 : ", $n，"<br/>"; // 变 量 n 传递 前 的 值 
echo "函数 中 : ", fun (Sn) ， "<br/>"; // 将 $n 的 值 传递 给 形 参 Snumber 
echo "传递 后 : ", Sn， "<br/>"7; // 实 参 的 值 发 生变 化 
2 
程序 运行 结果 如 图 4-3 所 示 。 


/se\. 











图 4-3 按 引 用 传递 方式 的 运行 结果 
程序 运行 过 程 中 的 内 存 分 配 图 ， 如 图 4-4 所 示 。 


形 参 $number 形 参 $number 
(a) 函数 调用 时 (b) 函数 调用 中 (©) 函数 调用 后 


图 4-4 按 引用 传递 时 ， 参 数 在 内 存 中 的 动态 分 配 


[及 提示 :， 在 使 用 按 引用 传递 方式 时 ， 函 数 fun( ) 被 调用 时 ， 系 统 为 形 参 $number 分 配 
了 内 存 空间 ， 此 时 形 参 gnumber 和 实 参 Sn 共同 指向 了 同一 个 变量 值 。 当 形 
ga 的 值 发 生变 化 时 ， 实 参 $n 的 值 也 同时 发 生变 化 。 当 函数 fun( ) 运 
行 完毕 结束 调用 时 ， 系 统 回收 调用 函数 期 间 分 配 的 所 有 内 存 空间 。 
3. 可 选 参数 (默认 参数 ) 
可 选 参数 就 是 指定 某 个 参数 为 可 选 参数 ， 将 可 选 参数 放 在 参数 列表 末尾 ， 并 且 指 定 其 
默认 值 为 空 。 
【实例 4-4】 函 数 参数 按 可 选 参数 传递 示例 。 


<?php 
header ("Content-Type:text/html;charset=gb2312"); 
function funl($value, $para="") // 最 后 一 个 参数 初始 值 为 空 
{ 
$value=$value+$para; 
echo $value, "<br/>"; // 函 数 内 输出 形 参 的 值 
} 
fun(10,2); // 可 选 参数 值 为 2 
fun(10); // 没 有 为 可 选 参 数 赋值 


fe 


程序 运行 结果 如 图 4-5 所 示 。 





图 4-5 ” 按 可 选 参 数 传递 方式 的 运行 结果 
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4.1.3 ”函数 的 返回 值 


在 PHP 中 ， 自 定义 函数 将 返回 值 传递 给 调用 者 的 方式 有 两 种 : 使 用 函数 returm( ) 返 
一 个 值 或 使 用 list( ) 语 言 结构 返回 多 个 值 。 


1. return( ) 函 数 


retum( ) 将 函数 的 值 返 回 给 函数 的 调用 者 ， 即 将 程序 控制 权 返 回 给 调用 者 的 作用 域 。 
【实例 4-5】 编 写 函数 circle( )， 其 功能 是 计算 圆 的 面积 。 


<?php 
header ("Content-Type:text/html;charset=gb2312"); 
function circle($r) 
{ 
$5=3.14*$r*$r; 
return $s; 
} 
$n=10; 
$area=circle ($n); 
echo " 圆 面积 : ", $area; 
A 


程序 运行 结果 : 
圆 面积 : 314 











苇 提示 :， retum 语句 只 能 返回 一 个 值 ， 不 能 一 次 返回 多 个 值 。 如 果 要 返回 多 个 结果 ， 


就 要 在 函数 中 定义 一 个 数组 ， 将 返回 值 存放 在 数组 中 返回 。 
2. list( ) 语 言 结 构 
通过 list( ) 语 言 结构 可 以 从 函数 中 返回 多 个 值 ，list( ) 的 语法 结构 为 
void list(varname 1,varname 2,...) 


list( ) 不 是 真正 的 函数 ， 而 是 语言 结构 ，list( ) 可 以 一 次 将 多 个 值 赋 给 不 同 的 变量 。 
【实例 4-6】 通 过 list( ) 语 言 结构 接收 函数 返回 的 多 个 值 。 


<?php 
function fun() 
{ 
$value[0]=10; 
$value [1]=20; 
$value [2]=30; 
return $value; // 返 回 数组 value 的 3 个 元 素 的 值 
} 
list ($a, $b, $c)=fun(); // 将 函数 fun () 的 返回 值 依次 赋 给 变量 $a、$b、$c 
echo "a=",$a, " b=",$b, " C=", SC7 
2 


程序 运行 结果 如 图 4-6 所 示 。 
/seN. 
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aF10 b=20 c=30 





4-6 ”通过 list( ) 接 收 函 数 返回 的 多 个 值 


[对 提示 : ”。list() 仅 能 用 于 数组 的 下 标 为 数字 的 ， 而 且 数 组 的 下 标 从 0 开始 。 
elist( ) 所 列 出 的 变量 个 数 不 能 多 于 函数 返回 值 的 个 数 ， 如 上 例 中 的 list( ) 语 
句 若 写 成 
list ($a, $b, $c, $d)=fun (); 


即 为 错误 ， 其 中 的 变量 8d 是 多 余 的 。 
4.2 变量 的 作用 域 


变量 的 作用 域 就 是 变量 的 适用 范围 。 根 据 变量 的 作用 域 可 以 将 变量 分 为 全 局 变量 和 局 
部 变量 。 变 量 在 PHP 程序 中 的 位 置 决 定 了 变量 的 作用 域 。 
局 部 变量 : 在 函数 内 部 定义 的 变量 (包括 函数 的 参数 )。 局 部 变量 在 函数 调用 结束 后 会 
被 系统 自动 回收 。 
全 局 变量 : 在 所 有 函数 之 外 定义 的 变量 。 全 局 变量 可 以 被 PHP 程序 中 的 所 有 语句 访问 
(不 包括 自 定义 函数 内 部 的 PHP 语句 )。 当 PHP 程序 执行 到 程序 末尾 的 时 候 ， 全 局 变量 才 会 
被 系统 自动 回收 。 全 局 变量 也 可 以 应 用 于 include 语句 和 require 语句 所 引用 的 PHP 程序 
文件 。 
如 果 某 函数 内 的 PHP 语句 要 访问 全 局 变量 ， 就 要 在 该 函数 内 定义 的 变量 前 加 关键 字 
global， 这 样 函数 外 部 的 全 部 变量 就 变 成 局 部 变量 了 。 
【实例 4-7】 全 局 变量 和 局 部 变量 应 用 示例 。 
<?php 
header ("Content-Type:text/html;charset=gb2312"); 
function fun(Sn) 
{ 
global $m; // 在 $m 变量 前 加 global， 则 可 访问 全 局 变量 m 
$m=$n+10; 
echo "函数 内 : ", $m,，"<br/>"; 
} 
$m=15; //$m 为 全 局 变量 
fun ($m); 
echo "函数 外 : ", $m,，"<br/>"; 





> 


程序 运行 结果 如 图 4-7 所 示 。 
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GD localhost/example 4-7.php 安 
函数 内 : 25 


函数 外 : 25 





图 4-7 实例 4-7 运行 结果 
当 程 序 调用 函数 fan0 时 ，PHP 预 处 理 器 创建 一 个 局 部 变量 (函数 形 参 )$Sn， 其 值 为 
15( 由 全 局 变量 $m 传递 )， 当 程序 执行 到 “global $m:” 时 ， 便 可 访问 全 局 变量 gm， 此 时 函 
数 内 部 的 变量 gm 和 函数 外 部 的 变量 Sm 为 同一 个 变量 ， 当 程序 执行 到 “$m=$n+10:” 时 ， 
全 局 变量 $m 的 值 变 为 5， 这 说 明 声 明 为 global 的 局 部 变量 ， 不 但 可 以 访问 同名 的 全 局 变 
量 ， 而 且 可 以 改变 同名 全 局 变量 的 值 。 
该 实例 中 的 内 存 动态 变化 如 图 4-8 所 示 。 
(a) 函数 调用 时 (b) 函数 调用 后 
图 4-8 全 局 变量 和 局 部 变量 在 内 存 中 的 动态 分 配 
时 提示 :  。 函数 的 参数 不 能 使 用 global 定义 。 


日 在 函数 内 部 使 用 global 声明 变量 时 ， 不 能 使 用 赋值 语句 为 该 变量 赋值 。 
例如 


global $m=10; 
就 是 错误 的 。 
。 使 用 global 语句 可 以 一 次 定义 多 个 变量 ， 如 


global $a, $b; 





4.3 变量 的 生存 周期 


在 函数 体内 定义 的 变量 的 生存 周期 开始 于 每 一 次 函数 调用 时 ， 结 束 于 本 次 函数 的 调用 
结束 时 刻 。 如 果 希 望 函 数 体内 的 变量 继续 存活 于 下 一 次 的 函数 调用 中 ， 此 时 就 要 在 该 变量 
前 加 上 关键 字 static， 将 该 变量 定义 为 静态 变量 。 

【实例 4-8】 静 态 变 量 与 普通 变量 的 区 别 。 

<?php 

header ("Content-Type:text/html;charset=gb2312"); 
function fun 1() 


static $m=10;  //s$m 为 静态 变量 
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Sm++7 
echo "静态 变量 ", $m，"<br/>"; 
} 
function fun 2() 
{ 
$n=10; //s$n 为 普通 变量 
Sn++7 
echo "普通 变量 ", $n，"<br/>"; 
» 
fun 1(); // 第 一 次 调用 
fune1()? // 第 二 次 调用 
fun 1(); // 第 三 次 调用 
fun_ 2(); // 第 一 次 调用 
fun_ 2(); // 第 二 次 调用 
fun_2(); // 第 三 次 调用 
?> 


程序 运行 结果 如 图 4-9 所 示 。 





4-9 ”静态 变量 与 普通 变量 的 区 别 


当 第 一 次 调用 函数 fun_1( ) 时 ， 执 行 语句 “static Sm;”， 此 时 在 内 存 中 创建 了 一 个 静态 
变量 $m， 执行 到 语句 “$m++;” 时 $m 的 值 变 为 11; 当 第 二 次 调用 函数 fun_1( ) 时 ， 由 于 内 
存 中 已 存 在 静态 变量 Sm， 程 序 将 不 再 执行 语句 “static Sm=10;”， 此 时 静态 变量 $m 仍然 保 
存 前 一 次 的 值 11; 当 执 行 到 语句 “$m++;” 时 ，S$m 的 值 变 为 12; 当 第 三 次 执行 函数 
fun_1( ) 时 ，Sm 的 值 就 变 为 3 。 当 所 有 的 代码 执行 完毕 ， 内 存 中 的 所 有 变量 都 被 回收 。 

而 每 次 调用 函数 fun_2( ) 时 ， 首 先 在 内 存 中 创建 普通 变量 Sn， 当 本 次 函数 调用 结束 
时 ， 内 存 中 的 变量 $n 就 被 回收 ， 故 普通 变量 的 值 不 会 被 累加 。 


本 章 小 结 
本 章 详细 介绍 了 自 定义 函数 的 定义 与 调用 方法 ， 自 定义 函数 参数 传递 的 方式 ， 变 量 的 
作用 域 以 及 变量 的 生存 周期 。 
习 。 丁 


1. 编写 一 个 函数 ， 计 算 圆 的 面积 。 
2. 编写 一 个 函数 ， 判 断 两 个 整数 中 的 较 大 者 。 
3. 编写 一 个 函数 ， 判 断 一 个 整数 是 否 为 素数 。 
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本 章 要 点 


@ ”数组 的 基本 概念 
@ 一 维 数 组 的 应 用 
@ 二 维 数 组 及 多 维 数组 的 基本 概念 


学 习 目 标 

@ ”掌握 数组 的 基本 概念 

@ 掌握 一 维 数组 的 应 用 

@ ”掌握 二 维 数组 的 简单 应 用 


数组 是 程序 设计 中 的 重要 内 容 ， 利 用 数组 可 以 对 大 量 性 质 相 同 的 数据 进行 存储 、 排 
序 、 插 入 、 删 除 等 操作 ， 进 一 步 提 高 程序 的 开发 效率 。 


5.1 数组 概述 
5.1.1 数组 的 基本 概念 


数组 是 一 组 数据 的 集合 ， 它 将 数据 按照 一 定 规则 排列 起 来 ， 形 成 一 个 可 操作 的 整体 。 
数组 中 的 每 一 个 数据 称 为 “元 素 ”， 元 素 之 间 相互 独立 ， 每 个 元 素 相当 于 一 个 变量 ， 元 素 
依靠 “ 键 ”(C 语言 称 之 为 “下 标 ”) 来 识别 。 


5.1.2 ”数组 的 分 类 


PHP 将 数组 分 为 一 维 数组 、 二 维 数组 和 多 维 数组 ， 但 不 管 是 一 维 数组 还 是 多 维 数组 ， 
都 可 以 将 其 分 为 数字 索引 数组 (indexed array) 和 关联 数组 (associative array)。 
1. 数字 索引 数组 


数字 索引 数组 的 键 名 (下 标 ) 由 数字 组 成 ， 默 认 从 0 开始 ， 每 个 数字 对 应 数组 元 素 在 数 
组 中 的 位 置 。 


2. 关联 数组 
关联 数组 的 键 名 (下 标 ) 可 以 由 数值 和 字符 串 混 合 组 成 。 


5.2 一 维 数 组 
5.2.1 一 维 数组 的 声明 
PHP 中 声明 一 维 数组 主要 有 两 种 方法 : 使 用 array( 函 数 声明 数组 和 直接 为 数组 元 素 赋 
值 的 方式 声明 数组 。 
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1. 使 用 array() 函 数 声明 数组 
使 用 arrayO 函 数 声明 数组 时 ， 数 组 的 键 名 既 可 以 是 数值 索引 也 可 以 是 关联 索引 。 键 名 


与 元 素 值 之 间 以 “=-> ”进行 连 接 ， 不 同 的 数组 元 素 用 逗号 分 隔 开 。 


【实例 5-1】 使 用 array0 函 数 声明 一 维 数组 ( 键 名 为 数字 )。 


<?php 
header ("Content-Type:text/html;charset=gb2312"); 
$a=array (1=>" 你 "2=>" 好 ", 3=>™ 世 "4=>" 界 "); 
echo $a[l],$a[2],$a[3],$a[4]; 
echo "<br/>"; 
2> 


程序 运行 结果 如 图 5-1 所 示 。 


€ © |D localhost/example_5-1.php 空 


你 好 世界 





5-1 实例 5-1 运行 结果 


使 用 array() 函 数 声明 数组 时 ， 数 组 的 键 名 也 可 以 是 字符 串 。 

【实例 $-2】 使 用 array0 函 数 声明 一 维 数组 ( 键 名 为 字符 串 )。 

<?php 
header ("Content-Type:text/html;charset=gb2312"); 
$color=array ("red"=>" 虹 *, “blue"=>" 蓝 ", "green"=>" 绿 ") > 
echo $color["red"], $color["blue"], $color["green"]; 

?2> 


程序 的 运行 结果 如 图 5-2 所 示 。 





图 5-2 实例 5-2 运行 结果 


2. 直接 为 数组 元 素 赋值 来 声明 一 维 数组 
【实例 5-3】 使 用 直接 为 数组 元 素 赋值 的 方式 声明 一 维 数组 。 


<?php 
header ("Content-Type:text/html;charset=gb2312"); 
$a[l]=" 你 "; 
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$al21=" 好 "™; 

$a[3]=" 世 "; 

$a[4]=" 界 "; 

print r($a); // 输 出 数组 $a 
?> 


程序 运行 结果 如 图 5-3 所 示 。 


localhoat/exanple_5-3 


€ C | BD localhost/example_5-3. phr 丈 


Array ( [1] => 你 [2] => 好 [3] => 世 [4] => 界 ) 





图 5-3 实例 5-3 运行 结果 
纯 提示 :  。 在 声明 数组 时 ， 也 可 以 不 指定 数组 元 素 的 “ 键 ”。 如 


<?php 
$b[]="red"; 
$b[]="blue"; 
?> 


当 数 组 元 素 的 键 没有 指定 时 ， 数 组 元 素 的 键 在 已 有 元 素 最 大 键 的 基础 上 
递增 1( 数 组 没有 整数 键 时 ， 则 从 0 开始 递增 1)。 上 述 程序 中 声明 的 数组 
元 素 等 价 于 $b[0]= "red"，$b[1]= "blue"。 
e PHP 数组 中 的 整数 “ 键 ”可 以 不 连续 。 如 
<?php 
$a[4]="red"; 
$a[2]="blue"; 
?> 


5.2.2 ”遍历 数组 


遍历 数组 就 是 按照 一 定 的 顺序 依次 访问 数组 中 的 每 一 个 元 素 ， 直 到 访问 完 为 止 。 在 
PHP 中 可 以 通过 流程 语句 (foreach 和 for 循环 语句 ) 或 函数 (list0 和 each()) 来 遍历 数组 。 


1. foreach 语句 遍历 数组 
【实例 5-4】 利 用 foreach 语句 遍历 一 维 数组 。 


<?php 
header ("Content-Type:text/html;charset=gb2312"); 
$str=array ("red"=>" 红 ", "blue"=>" 蓝 ", "green"=>" 绿 "); 
foreach ($str as $link) 
echo Slink.™ ™> 
人 2 
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程序 运行 结果 如 图 5-4 所 示 。 





图 5-4 实例 5-4 运行 结果 


2. for 循环 语句 遍历 数组 


如 果 要 遍历 的 数组 是 数字 索引 数组 ， 而 且 数 组 的 键 值 为 连续 的 整数 ， 此 时 可 以 使 用 for 
循环 语句 来 遍历 。 此 时 需要 用 count0 函 数 获取 数组 中 元 素 的 数量 。 

【实例 $S-S】 利 用 for 循环 语句 遍历 一 维 数组 。 
<?php 

header ("Content-Type:text/html;charset=gb2312"); 

$str=array (0=>"C 语言 ", 1=>"Viusal Basic",2=>"PHP"); 

for ($i=0; $i<count ($str); $i++) 

echo $str[$i]."<br/>"; 

?> 


程序 运行 结果 如 图 5-5 所 示 。 


cealhozt/ezasple_5-5 


人 GD localhost 


C 语 言 


Viusal Basic 


PHP 





图 5-5 实例 5-5 运行 结果 
3. 通过 函数 list() 和 each() 遍 历数 组 
list0 函 数 将 数组 元 素 的 值 赋予 一 些 变量 ， 其 语法 格式 如 下 : 
void list(varl,var2,...) 
函数 参数 说 明 如 表 5-1 所 示 。 
表 5-1 list() 函 数 参数 说 明 
说 明 
必需 。 第 一 个 需要 赋值 的 变量 
可 选 。 可 以 有 多 个 变量 
函数 功能 : 将 数组 中 元 素 的 值 赋 给 一 组 变量 。 该 函数 仅 能 应 用 于 数字 索引 的 数组 ， 键 
从 0 开始 。 
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each() 函 数 返 回 数 组 元 素 的 键 名 和 对 应 的 值 ， 其 语法 格式 如 下 : 


array each (array) 
函数 参数 说 明 如 表 5-2 所 示 。 
表 5-2 函数 each() 的 参数 说 明 


参 数 说 明 
arra 必需 。 要 读 取 的 数组 


函数 功能 : each(O) 函 数 生成 一 个 由 数组 指针 所 指向 的 元 素 的 键 名 和 键 值 组 成 的 数组 。 
车 数组 指针 越过 了 数组 范围 ，each0 函 数 将 返回 FALSE。 
【实例 5-6】 利 用 list0 和 each0 函 数 遍 历 一 维 数组 。 

<?php 
header ("Content-Type:text/html;charset=gb2312"); 
$str=array ("0"=>" 北 京 ", "1"=>" 上 海 ", "2"=>" 广 州 ") ; 
While (list ($key, $value)=each ($str)) //1ist 函数 获取 each 函数 返回 数 

echo "$key=>$value.<br/>"; // 组 元 素 的 键 和 值 ， 并 分 别 赋予 
3 // 变 量 $key 和 $value 


程序 运行 结果 如 图 5-6 所 示 。 











图 5-6 实例 5-6 运行 结果 


5.3 多 维 数 组 


如 果 数 组 元 素 中 的 “ 值 ”是 另 一 个 数组 ， 此 时 数组 就 是 一 个 二 维 数组 ， 甚 至 是 多 维 数 
组 。 由 于 在 实际 编程 中 很 少 涉及 多 维 数 组 ， 因 此 本 节 主 要 介绍 二 维 数组 的 应 用 。 


5.3.1 二 维 数组 的 声明 


二 维 数组 的 创建 可 以 通过 array0O 函 数 来 实现 。 
【实例 5-7】 利 用 array0 函 数 创建 二 维 数组 。 


<?php 
header ("Content-Type:text/html;charset=gb2312"); 
// 声 明 二 维 数组 
$a=array ("计算 机 "=>array ("PHP", "JAVA","C 语言 ") ， 
"经 济 "=>array ("会 计 ", "国际 贸易 ", "金融 ") ， 
"历史 "=>array ("春秋 ", "战国 "," 左 传 ") ) ; 








.6a， 





// 输 出 数组 元 素 
print r($a); 
区 2 


程序 运行 结果 如 图 5-7 所 示 。 


上 localhost/exanmple_5-7.p 


Array 〔 [计算 机 ] => Array ( [0] => PHP [1] => JAVA 


[2] => Cc 语言 ) [经 济 ] => Array ( [0] => 会 计 [1] => 
国际 贸易 [2] => 金融 ) [历史 ] =>Array( [0] => 春秋 
[1] => 战国 [2] => 左 传 ) ) 





图 5-7 二 维 数组 的 结构 


二 维 数组 的 元 素 的 排列 类 似 于 二 维 表 ， 数 组 的 第 一 个 “ 键 ” 相 当 于 二 维 表 中 的 
“ 行 ”， 数 组 的 第 二 个 “ 键 ” 相 当 于 二 维 表 中 的 “ 列 ”， 二 维 数组 的 结构 如 表 5-8 所 示 。 





厦 他 | 小 


图 5-8 二 维 数组 与 二 维 表 
5.3.2 二 维 数 组 元 素 的 访问 


由 于 二 维 数组 中 存在 两 个 “ 键 ”， 因 此 ， 要 访问 二 维 数组 的 元 素 的 值 ， 首 先 要 确定 这 
两 个 “ 键 ”。 
【实例 5-8】 访 问 二 维 数组 元 素 。 


<?php 
header ("Content-Type:text/html;charset=gb2312"); 
$a=array ("计算 机 "=>array ("PHP", "JAVA", "C 语言 ")， 
"经 济 "=>array ("会 计 ", "国际 贸易 ", "金融 ") ， 
"历史 "=>array ("春秋 ", "战国 "," 左 传 ") ) ; 
echo $a[" 计 算 机 "] [0]; // 输 出 二 维 数组 的 元 素 


> 


程序 运行 结果 如 图 5-9 所 示 。 


PHP 





图 5-9 二 维 数组 元 素 的 访问 
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| 刚 | 说 明 : 。 二 维 数 组 元 素 $a[ 计 算 机 ][0] 对 应 的 值 是 “PHP”， 其 中 第 一 个 键 “ 计 算 
机 ”用 于 确定 二 维 数组 的 某 一 行 ， 第 二 个 键 “0” 用 于 确定 二 维 数组 “ 计 
算 机 ” 行 的 某 一 列 。 
@ 只 使 用 第 一 个 键 访问 数组 时 ， 访 问 的 是 数组 的 菜 一 行 ， 该 行 是 一 个 一 维 
数组 ， 例 如 $a[ 计 算 机 ] 对 应 的 就 是 一 维 数组 。 


5.4 ”PHP 全 局 数组 


PHP 提供 了 大 量 的 全 局 数组 ， 利 用 这 些 数组 可 以 获取 与 环境 相关 的 信息 。 比 如 : 当前 
用 户 会 话 信息 、 用 户 操作 环境 信息 、 本 地 操作 环境 信息 等 。 








5.4.1 $_SERVERI[] 全 局 数组 


$_SERVERI[] 全 局 数组 包含 由 Web 服务 器 创建 的 信息 ， 利 用 这 些 数组 可 以 获取 服务 器 
和 客户 配置 以 及 当前 请 求 的 有 关 信息 。$_SERVER[] 的 相关 数组 说 明 如 表 5-3 所 示 。 
表 5-3 $_SERVER[ 全 局 数组 








数组 元 素 说 明 
$_SERVER["SERVER_ADDR'"] 去 行 脚本 所 在 服务 器 的 了 地址 
$_SERVER["SERVER_NAME"] 当前 运行 脚本 所 在 服务 器 主机 的 名 称 
$_SERVER["REQUEST_METHOD"] 访问 页 面 的 提交 方法 ， 如 : GET、POST、PUT 
$_SERVER["REMOTE_ADDR"] 浏览 当前 页 面 的 用 户 的 耳 地 址 
$_SERVER["REMOTE_HOST"] 正在 浏览 当前 页 面 的 用 户 的 主机 名 
$_SERVER["REMOTE_PORT"] 用 户 连 接 到 服务 器 所 使 用 的 端口 
$_SERVER["SCRIPT_FILENAME"] 当前 执行 脚本 的 绝对 路 径 
$_SERVER["SERVER_PORT"] 服务 器 所 使 用 的 端口 
$_SERVER["SERVER_SIGNATURE"] 包含 服务 器 版 本 和 虚拟 主机 名 的 字符 串 
$_SERVER["DOCUMENT_ROOT"] 当前 运行 脚本 所 在 的 文档 根 目录 

【实例 5-9】 利 用 $_SERVER[] 全 局 数组 获取 服务 器 所 在 的 IP 地 址 及 服务 器 的 相关 
信息 。 
<?php 


header ("Content-Type:text/html;charset=gb2312"); 

echo "当前 服务 器 IP 地 址 : ".$_SERVER["SERVER_ADDR"] ."<br/>"; 

echo "当前 服务 器 的 主机 名 : ".$_SERVER["SERVER_NAME"] ."<br/>"; 

echo "用 户 IP 地 址 : ".$_SERVER["REMOTE_ADDR"] ."<br/>"; 

echo "当前 运行 程序 所 在 的 根 目录 : ".$_SERVER["DOCUMENT_ROOT"] ."<br/>"; 
区 二 


程序 运行 结果 如 图 5-10 所 示 。 
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localhoat/exasple_5-17 


和 外 | 口 localhost/example_5-17.php 安 
当前 服务 器 IP 地 址 ， 





有 和约 王 机 各 ， aat 
用 户 IP 地 址 ， 
当前 运 和 村 东 在 的 根 目录 ， C:/xampp/htdocs 





图 5-10 实例 5-9 运行 结果 


[对 提示 : ” 当 计算 机 开启 了 IPv6 支持 ， 且 浏览 器 使 用 localhost 访问 本 机 时 ， 则 本 机 的 
IP 地 址 显示 为 “::]”。 若 浏览 器 以 卫 地 址 “127.0.0.1” 访 问 本 机 ， 则 显示 
的 效果 如 图 5-11 所 示 。 


园 127.0.0. ezasple_5-17 
€ © ID 127. 


当前 服务 器 IP 地 址 ，127. 0. 0. 1 
岩 间 最 各 疡 的 走 机 名 ， 127.0.0.1 
用 户 IP 地 址 ，127. 0. 0. 1 
当前 运行 程序 所 在 的 根 目录 ，C:/xampp/htdocs 





图 5-11 以 IP 地 址 “127.0.0.1” 访 问 本 机 的 运行 结果 
5.4.2 $_GET[] 和 $_POST[] 全 局 数组 


PHP 提供 的 $_GET[] 和 $_POST[] 全 局 数组 分 别 用 来 接收 GET 方法 和 POST 方法 传递 到 
当前 页 面 的 数据 。 以 GET 方法 传递 的 页 面 数据 ， 会 以 查询 字符 串 的 形式 显示 在 浏览 器 的 
地 址 栏 中 ， 而 以 POST 方法 传递 的 页 面 数据 则 不 会 显示 在 浏览 器 的 地 址 栏 中 。 

【实例 5-10】 通 过 GET 方法 获取 用 户 提交 的 注册 信息 。 
创建 静态 网 页 login.html， 在 页 面 上 放置 的 表单 控件 信息 如 表 5-4 所 示 。 


表 5-4 表单 控件 信息 











控件 名 称 说 明 
User_name Text 登录 用 户 名 
password Password 登录 密码 
email Text 用 户 的 邮箱 地 址 
login html 文件 代码 如 下 : 
<html> 
<head> 


<meta http-equiv="Content-Language" content="zh-cn"> 

<meta http-equiv="Content-Type" content="text/html; charset=gb2312"> 
<title> 注 册 信 息 </title> 

</head> 
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<body> 

<form method="GET" action="upload.php"> 
<p> 用 户 名 : <input type="text" name="user name" size="32"></p> 
<p> 密 码 : <input type="password" name="password" size="34"></p> 
<p> 邮 箱 : <input type="text" name="email" size="34"></p> 

<p><input type="submit" value=" 提 交 " name="B1"></p> 

</form> 

</body> 

</html> 


创建 PHP 程序 文件 upload.php， 用 以 接收 login.html 传递 的 数据 ， 程 序 代 码 如 下 : 


<?php 
header ("Content-Type:text/html;charset=gb2312"); 
echo "用 户 名 : ".$_GET["user name"] ."<br/>"; 
echo "密码 : ".$_GET["password"] ."<br/>"; 
echo "邮箱 : ".$_GET["email"]."<br/>"; 
?> 


login.html 页 面 启动 如 图 5-12 所 示 ， 提 交 后 页 面 运 行 如 图 5-13 所 示 。 




















邮箱 ，[hengii@sina com 


提交 | 





5-12 ”login.html 页 面 


加 iocalhost /vplond ptr x 全 
€ 3 © |D localhost/upload. php?user_name=SCOSEESCASA4SCOXFB&pa 


用 户 名 ， 李 胜利 
密码 ，abc123 
邮箱 ，shengli_ligsina. com 





5-13 ”GET 方法 提交 数据 的 运行 结果 


【实例 5-11】 通 过 POST 方法 获取 用 户 提交 的 注册 信息 。 
将 实例 5-10 中 login.html 中 method="GET" 改 为 method="POST"， 将 upload.php 中 所 


有 的 $_GET 改 为 $ POST， 则 upload.php 的 代码 为 : 


Tn 


<?php 
header ("Content-Type:text/html;charset=gb2312"); 
echo "用 户 名 : ".$_POST["user name"] ."<br/>"; 
echo "密码 : ".$_POST["password"] ."<br/>"; 
echo "邮箱 : ".$_POsST["email"]."<br/>"; 
2 


币 5 交 组 人 


login html 页 面 启动 后 输入 相应 的 信息 ， 提 交 信 息 启 动 upload.php 后 ， 浏 览 器 的 地 址 栏 
中 没有 所 提交 的 用 户 名 、 登 录 密 码 等 信息 ， 程 序 运 行 结 果 如 图 5-14 所 示 。 


回 :cahozt/oplad rp x We 
所 © | 口 localhost/upload.php 


用 户 名 ， 李 胜利 
密码 ，abc123 


箱 :，shengli_li@sina. com 





图 5-14 POST 方法 提交 数据 的 运行 结果 
5.4.3 $_REQUEST[] 全 局 数组 


可 以 通过 $_REQUEST[] 全 局 数组 获取 GET 方法 、POST 方法 和 HTTP Cookie 传递 到 
脚本 的 信息 。 在 编写 程序 时 ， 如 果 不 知道 是 通过 什么 方式 提交 的 数据 ， 就 可 以 使 用 
$_REQUEST[] 全 局 数组 获取 提交 到 当前 页 面 的 数据 。 实 例 5-11 中 的 upload.php 程序 可 以 
修改 为 : 

<?php 

header ("Content-Type:text/html;charset=gb2312"); 
echo "用 户 名 : ".$_REQUEST["user-name"] ."<br/>"; 
echo "密码 : ".$_REQUEST["password"] ."<br/>"; 


echo "邮箱 : ".$_REQUEST["email"]."<br/>"; 
?> 


5.4.4 $_COOKIE[ ] 全 局 数组 


$_COOKIE[] 全 局 数组 存放 了 通过 HTTP Cookie 传递 给 脚本 的 信息 。PHP 中 可 以 通过 
setcookie() 函 数 设 置 Cookie 的 值 ， 用 $_COOKIE[] 数 组 接收 Cookie 的 值 ， $_COOKIE 数 
组 的 下 标 为 Cookie 的 名 称 。 


5.4.5 $_SESSION[] 全 局 数组 


$_SESSION[] 全 局 数组 用 于 获取 会 话 变量 的 相关 信息 。 关 于 $_COOKIE[] 和 $_SESSION[] 
全 局 数组 的 应 用 将 于 第 10 章 详 细 讲 解 。 


5.4.6 $_ENV[] 全 局 数组 


$_ENV[] 全 局 数组 用 于 提供 服务 器 的 相关 信息 ， 如 : $_ENV["HOSTNAME"] 获 取 服 务 
器 的 名 称 。 
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5.4.7 $_FILES[] 全 局 数组 





$_FILES[] 全 局 数组 用 于 获取 一 个 上 传 文件 时 的 相关 信息 。 该 数组 为 多 维 数组 ， 若 上 传 
1 个 文件 ， 该 数组 为 二 维 数组 ， 若 上 传 多 个 文件 ， 该 数组 为 三 维 数组 。 下 面 对 该 数组 的 参 
数 进行 说 明 ， 如 表 5-5 所 示 。 


表 5-5 $_FILES[] 全 局 数组 的 参数 说 明 





参数 项 
$_FILES["file"]["name"] 


$_FILES["file"]["type"] 
$_FILES["file"]["size"] 
$_FILES["file"]["tmp_name"] 
$_FILES["file"]["error"] 


说 明 





上 传 文件 的 名 称 

上 传 文件 的 文件 类 型 

上 传 文件 的 大 小 

文件 上 传 到 服务 器 后 ， 为 文件 命名 的 临时 文件 名 
返回 在 上 传 文件 过 程 中 发 生 错 误 的 代号 














本 章 小 结 


本 章 详细 介绍 了 一 维 数组 、 二 维 数组 的 定义 以 及 数组 元 素 的 引用 方法 ， 并 介绍 了 PHP 
的 全 局 数组 及 其 应 用 方法 。 


习 题 
1. 有 一 数组 $a=array(20.34.12.54.64.43.7): 请 按 由 小 到 大 的 次 序 重 新 排序 。 


2. 有 一 数组 $b=array(15,30,45,123,67,98,26,75,6,234); 将 其 逆序 输出 。 
3. 有 一 数组 $b=array(115.320.415.23.167.98.36.35.76.134): 找 出 其 最 大 值 。 
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本 章 要 点 

@。” 宁 符 囊 的 概念 

@ ”字符 囊 的 操作 夯 数 

学 习 目 标 

@ ”了 和 解 字符 囊 的 概念 

@ 掌握 字符 囊 操作 函数 的 应 用 方法 


6.1 字符 串 简介 


字符 串 是 由 一 对 单 引 号 () 或 一 对 双 引 号 (") 包 含 的 零 个 或 多 个 字符 组 成 的 一 个 集合 。 构 
符 串 的 字符 主要 包括 以 下 几 种 类 型 。 
@ ”字母 类 型 A、B、a、b 等。 
@ ”数字 类 型 ， 1、2 等 。 

@ ”特殊 字符 : #、*、+、^ 等 。 
@ 

其 

果 

三 





成 字 和 


不 可 见 字 符 : \n( 换 行 符 )、\r( 回 车 符 )、\t(Tab 字符 ) 等 。 





串 的 界定 符号 有 以 下 3 种 。 
@ 单 引 号 ()。 

@ 双 引 号 ()。 

@ 界定 符 (<<<)。 





6.2 字符 串 操作 
6.2.1 获取 字符 串 长 度 


字符 串 长 度 函数 包括 sttlen0 函 数 和 mb_strlen0) 函 数 。 
1. strlen() 函 数 

函数 的 语法 格式 如 下 : 

int strlen(string str) 

函数 功能 : 返回 字符 串 str 的 字符 长 度 。 

【实例 6-1】 使 用 strlen0 函 数 计算 字符 串 的 长 度 。 


<?php 
$str="hello 世界 "; 
echo strlen($str); 





2> 
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程序 运行 结果 : 

kd 
[ 纯 提示 : 对 函数 strlen() 来 说 ， 当 PHP 采用 的 字符 集 为 UTF-8 时 ， 则 一 个 英文 字符 占 

一 个 字 节 长 度 ， 一 个 汉字 占 两 个 字 节 长 度 。 

2. mb_strlen() 函 数 

函数 的 语法 格式 如 下 : 

int mb_strlen(string str,string encoding) 

函数 功能 : 根据 设 定 的 编码 方式 ， 返 回 字 符 串 所 包含 的 字符 数 ， 多 字 节 的 字符 被 计 
为 1。 

函数 的 参数 说 明 如 表 6-1 所 示 。 


表 6-1 函数 mb_strlen() 的 参数 说 明 





参 数 描 述 
str 规定 要 处 理 的 字符 串 
可 选 。 规 定 字符 串 的 编码 方式 。 常 用 的 编码 方式 如 下 : 
i "gb2312" 或 "gbk"， 一 个 英文 字符 占 一 个 字 节 长 度 ， 一 个 汉字 占 两 个 字 节 长 度 ; 
utf-8"， 每 个 中 文 或 英文 字符 均 占 一 个 字 节 长 度 。 
默认 采用 PHP 内 部 字符 编码 utf-8 
【实例 6-2】 使 用 函数 mb_strlen0 计 算 字 符 串 的 长 度 。 
<?php 


$str=" 你 好 world"; 
echo "中 文 gb2312 编码 方式 : ",mb_strlen ($str, "gb2312"), "<br/>"; 
echo "utf-8 编码 方式 : ",mb_strlen ($str, "utf-8"), "<br/>"; 

?> 


程序 运行 结果 如 图 6-1 所 示 。 


localhost/exa=sple_6-5.5 X 


€ © |D localhost/example_6-5. php 
中 文 gb2312 编 码 方式 ，7 


utf-8 编 码 方式 :7 





6-1 实例 6-2 的 运行 结果 


苇 提示 : 。 mb_strlen0 函 数 只 是 返回 字符 囊 所 包含 的 字符 个 数 ， 而 strlen0 〇 函数 是 计算 字 
符 囊 所 占用 的 字 节 长 度 。 因 此 mb_strlen() 函 数 更 适合 处 理 包 含 中文 的 字符 串 。 
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6.2.2 ”截取 字符 串 


规定 要 处 理 的 字符 串 


可 选 。 截 取 的 子 字符 串 的 长 度 。 若 忽略 ， 则 取 到 字符 串 的 尾 端 。 


字符 呈 





截取 函数 包括 substr0 函 数 和 mb_substr0 函 数 。 


1. substr() 函 数 
函数 的 语法 格式 如 下 : 


string substr (String str,int start, int length) 





Str 


Start 


length 


函数 功能 


表 6-2 ”函数 substr() 的 参数 说 明 
描 述 


截取 字符 串 的 开始 位 置 。 

正 数 : 从 字符 串 的 指定 位 置 开始 ; 
负数 : 从 字符 串 结尾 处 指定 的 位 置 开 始 
0: 从 字符 串 左 端 第 一 个 字符 处 开始 


正 数 : 从 start 所 在 的 位 置 开始 从 左 向 右 返 回 的 长 度 ; 
负数 : 从 字符 串 末 端 从 右 向 左 返 回 的 长 度 





【实例 6-3】 使 用 函数 substr0 截 取 字符 串 。 


<?php 
header ("Content-Type:text/html;charset=gb2312"); 
$str="Hello world"; 

" 左 起 第 1 个 向 右 截取 5 个 字符 : ", substr ($str,0,5),"<br/>"; 


> 


程序 


78. 


echo 
echo 
echo 
echo 
echo 


运行 


" 左 起 第 3 个 到 结尾 : ", substr ($str,2)，, "<br/>"; 


: 从 str 字符 串 中 的 start 位 置 截取 长 度 为 length 的 子 字符 串 。 
函数 的 参数 如 表 6-2 所 示 。 


" 右 起 第 3 个 向 右 截取 2 个 字符 : ", substr ($str, -3,2), "<br/>"; 


" 右 起 第 5 个 到 右 起 第 3 个 之 前 的 字符 : ", substr ($str, 
" 右 起 第 5 个 到 结尾 : ", substr ($str,-5), "<br/>"; 


结果 如 图 6-2 所 示 。 


园 :ccalhoat/era=ple 6-2 上 x 
€ C |D localhost/example_6-2. php Ys 
左 起 第 1 个 向 右 截取 5 个 字符 ，Hello 


右 起 第 5 个 到 右 起 第 3 个 之 前 的 字符 :mo 
右 起 第 5 个 到 结尾 ，world 


6-2 ”实例 6-3 的 运行 结果 





-5,-3), "<br/>"; 


第 6 意 宁 符 让 处 理 人 


[时 提示 : 对 substr0) 函 数 来 说 ， 一 个 中 文字 符 占用 两 个 字 节 长 度 ， 因 而 在 使 用 substr0 
函数 截取 中 文字 符 串 时 ， 有 可 能 会 导致 乱码 。 例 如 以 下 代码 : 
<?php 
header ("Content-Type:text/html;charset=gb2312"); 
$str=" 学 习 PHP 程序 "; 
echo substr ($str,1,5),"<br/>"; 
时 


程序 运行 后 出 现 乱码 情况 ， 如 图 6-3 所 示 。 


回 :ccalho:t/eza=ple_ 5-6-0 x 证 >= 
Ss © | D localhost/exa 
疗 H 





6-3 ”susbstr() 函 数 截取 中 文字 符 串 出 现 乱码 的 情况 


使 用 mb_substr0 函 数 或 mb_streut0 函 数 可 以 解决 截取 中 文字 符 串 出 现 乱 码 的 问题 。 
2. mb_substr() 函 数 

函数 的 语法 格式 如 下 : 

string mb_substr (string str,int start,int length,encoding) 

函数 功能 :， 同 substr0 函 数 大 致 相同 。 


函数 的 参数 同 substr0 大 致 相同 ， 其 中 encoding 表示 编码 的 方式 ， 一 般 取 gb2312、gbk 
或 utf-8。 


【实例 6-4】 使 用 函数 mb_substr0 截 取 字 符 串 。 


<?php 
header ("Content-Type:text/html;charset=gb2312"); 
$str=" 学 习 PHP 程序 "; 
echo "中 文 编码 方式 : ", mb_substr ($str,0,5,"gb2312"), "<br/>"; 
echo "UTF-8 编码 方式 : ",mb_substr ($str,0,5,"utf-8"), "<br/>"; 





人 


程序 运行 结果 如 图 6-4 所 示 。 


国 1cealhost /eranp1e 6-7 x 且 到 
€ 3 © Dlocalhost/exanple 6-7. php 
中 文 编码 方式 ， 学 习 PHP 


TUTF-8 编 码 方式 ， 学 习 PHP 





6-4 实例 6-4 的 运行 结果 
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3. mb_strcut() 函 数 
函数 的 语法 格式 如 下 : 


string mb strcut (string str,int start,int length,encoding) 











函数 功能 : 同 mb_substr0 函 数 大 致 相同 。 
函数 的 参数 同 md_substr0 大 致 相同 。 








【实例 6-5】 使 用 函数 mb_strcutO 截 取 字 符 串 。 


<?php 
header ("Content-Type:text/html;charset=gb2312"); 
$str=" 学 习 程序 设计 "; 
echo "中 文 编码 方式 : ",mb_strcut ($str,0,5,"gb2312"), "<br/>"; 
echo "UTF-8 编码 方式 : ",mb_strcut ($str,0,5,"utf-8"), "<br/>"; 
?> 


程序 运行 结果 如 图 6-5 所 示 。 


回 :ccalho:veza=rle 5-5.5 x >= 
和 @ | BD localhost/example_6-8.php 灾 


中 文 编码 方式 ,学 习 


TF-8 编 码 方式 ， 学 习 仿 





图 6-5 ”实例 6-5 运行 结果 


叶 提示 : mb_streut0 函 数 采 取 的 encoding 值 为 gb2312 或 gbk 时 ， 是 按照 字 节 来 切 分 
字符 的 。 当 mb_strcut() 吉 数 采用 的 编码 方式 与 PHP 内 部 采用 的 编码 方式 不 
一 致 时 ， 截 取 中 文字 符 串 时 会 出 现 乱码 的 情况 。 


6.2.3 ”操作 子 字符 串 


子 字符 串 的 操作 主要 包括 : 确定 子 字 符 串 的 位 置 、 查 找 子 字符 串 以 及 统计 子 字符 串 出 
现 的 次 数 等 。 
1. 确定 子 字符 串 的 位 置 


确定 子 字符 串 位 置 的 函数 主要 包括 strpos0 〇 函数 、strpos0 函 数 、mb_strpos0 函 数 和 
mb_strrpos() 函 数 。 

(1) strpos0 〇 函数 。 

函数 的 语法 格式 如 下 : 


int strpos (string str, string substr, int offset) 


函数 功能 : 在 字符 串 str 中 以 区 分 大 小 写 的 方式 查找 子 字 符 串 substr 第 一 次 出 现 的 位 
置 。 若 substr 不 在 str 中 ， 函 数 返 回 FALSE。 
函数 的 参数 说 明 如 表 6-3 所 示 。 
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表 6-3 函数 strpos() 的 参数 说 明 








参 数 描 述 
了 规定 要 搜索 的 字符 品 
be | 要 查找 的 子 字符 品 
offset 可 选 。 指 定 从 st 的 哪个 位 置 开始 查找 ， 默 认 从 第 一 个 字符 开始 查找 








【实例 6-6】 使 用 函数 sttposO 查 找 子 字符 串 第 一 次 出 现 的 位 置 。 





<?php 
$str="Study PHP,Use PHP"; 
echo strpos($str,"PHP"); 
> 
程序 运行 结果 为 : 
6 


(2) strrpos0) 函 数 。 

函数 的 语法 格式 如 下 : 

int strrpos (string str, string substr, int offset) 

函数 功能 : 在 字符 串 str 中 以 区 分 大 小 写 的 方式 查找 子 字符 串 substr 最 后 一 次 出 现 的 位 
若 substr 不 在 str 中 ， 函数 返回 FALSE。 
strrpos() 函 数 的 参数 含义 与 strrpos() 函 数 的 参数 含义 大 致 相同 。 

【实例 6-7】 使 用 函数 strposO 查 找 子 字符 串 最 后 一 次 出 现 的 位 置 。 
<?php 

$str="Study PHP,Use PHP"; 


echo strrpos($str,"PHP"); 
> 


程序 运行 结果 为 : 
14 


Ge 





(3) mb_strpos( 〇 函数。 
函数 的 语法 格式 如 下 : 


int mb_strpos(string str, string substr, int offset, string encoding) 


函数 功能 : 与 strpos() 函 数 的 功能 大 致 相同 ， 只 是 mb_strpos0 〇 函数 可 以 设置 用 encoding 
编码 方式 来 解析 字符 串 str。 
【实例 6-8】 使 用 函数 mb_strpos() 查 找 子 字符 串 第 一 次 出 现 的 位 置 。 
<?php 
$str=" 学 习 PHP, 应 用 PHP"; 
ccho mo strpos(ldstr "PHP 0 "utr=8%) 
?> 
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程序 运行 结果 为 : 


2 

(4) mb_strrpos( 〇 函数 。 

函数 的 语法 格式 如 下 : 

int mb _strrpos (string str, string substr, int offset,string encoding) 

函数 功能 : 与 stmposO 函 数 的 功能 大 致 相同 ， 只 是 在 mb_strrpos0 函 数 中 可 以 设置 用 
encoding 编码 方式 来 解析 字符 串 str。 

函数 的 参数 含义 与 函数 strpos() 的 参数 含义 大 致 相同 。 

【实例 6-9】 使 用 函数 mb_strrpos0 〇 查找 子 字符 串 最 后 一 次 出 现 的 位 置 。 


<?php 
$str=" 学 习 PHP, 运用 PHP"; 
echo mb_strrpos ($str,"PHP",0,"utf-8"); 








?> 
程序 运行 结果 为 : 
8 


苇 提示 :， stmposO 函 数 和 strposO 函 数 适 合 于 在 英文 字符 串 中 定位 ，mb_strpos(O 函 数 和 
mb_strrpos() 函 数 适 合 于 在 中 文字 符 串 中 定位 。 
2. 查找 子 字符 串 
字符 串 的 查找 方法 分 为 两 类 : 一 类 是 区 分 字母 大 小 写 的 ， 主 要 通过 函数 strstr0 和 
strrchr(0 来 实现 ， 另 一 类 是 不 区 分 字母 大 小 写 的， 可 以 通过 函数 stristr() 来 实现 。 
(1) strstr0 函 数 。 
函数 的 语法 格式 如 下 : 
string strstr(string str, mixed search, bool before search) 
函数 功能 : 查找 字符 串 search 在 另 一 字符 串 str 中 第 一 次 出 现 的 位 置 ， 并 返回 从 该 位 
置 到 str 结尾 的 所 有 字符 。 若 未 找到 ， 函 数 返 回 FALSE。 
函数 的 参数 说 明 如 表 6-4 所 示 。 
表 6-4 函数 strstr() 的 参数 说 明 





说 明 





规定 被 搜索 的 字符 串 

规定 所 搜索 的 字符 串 

可 选 。 默 认 值 为 FALSE。 若 设置 为 TRUE， 则 返回 search 第 一 次 出 现 之 前 的 字符 串 部 分 
【实例 6-10】 使 用 函数 strstr0 查 找 字 符 串 。 


<?php 
header ("content-type:text/html;charset=gb2312"); 


str 





search 











before_search 
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$str = "Hello world"7 


echo "所 查 字符 串 及 剩余 部 分 : ", strstr ($str, "wor"),"<br/>"; 
echo "所 查 字 符 串 之 前 部 分 :", strstr ($str, "world", true); 


2> 


程序 运行 结果 如 图 6-6 所 示 。 


回 1--alhost/e=a=ple 5-13 x > 
€ @ | localhost/example 6-13.php 3 
所 查 字符 串 及 剩余 部 分 ，world 


所 查 字符 串 之 前 部 分 :Hello 





图 6-6 实例 6-10 的 运行 结果 
(2) strrchr0 函 数 。 
函数 的 语法 格式 如 下 : 
string strrchr (string str, mixed search) 
函数 功能 : 查找 字符 串 search 在 另 一 字符 串 str 中 最 后 一 次 出 现 的 位 置 ， 并 返回 从 该 


位 置 到 str 结尾 的 所 有 字符 。 若 未 找到 ， 函 数 返 回 FALSE。 
函数 的 参数 说 明 如 表 6-5 所 示 。 


表 6-5 函数 strrchr() 的 参数 说 明 





规定 被 搜索 的 字符 串 

规定 所 搜索 的 字符 串 
【实例 6-11】 使 用 函数 strrchr() 查 找 字符 串 。 
<?php 


header ("content-type:text/html;charset=gb2312"); 
$str = "line 1,1ine 2,1ine 3"7 


echo "所 查 字 符 串 及 剩余 部 分 : ", strrchr ($str, "line"); 
2> 


程序 运行 结果 如 图 6-7 所 示 。 
localhost/ezasple_6-14 X 


€ © DD localhost/examp 
所 查 字 符 串 及 箱 | 余 部 分 ，line 3 





图 6-7 实例 6-11 的 运行 结果 
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(3) stristr0 函 数 。 
函数 的 语法 格式 如 下 : 
string stristr(string str, mixed search, bool before search) 


函数 功能 : 查找 字符 串 search 在 字符 串 str 中 最 后 一 次 出 现 的 位 置 ， 并 返回 从 该 位 置 
到 str 结尾 的 所 有 字符 。 若 未 找到 ， 函 数 返 回 FALSE。stristr0 函 数 的 功能 及 参数 含义 与 
strstr() 函 数 的 功能 及 参数 含义 相同 ， 只 是 函数 stristr0 不 区 分 字母 大 小 写 。 
【实例 6-12】 使 用 函数 stristr0 查 找 字 符 串 。 
<?php 
header ("content-type:text/html;charset=gb2312"); 
$str = "Hello WORLD"; 
echo "所 查 字符 串 及 剩余 部 分 : ", stristr($str, "wor"), "<br/>"; 
echo "所 查 字 符 串 之 前 部 分 :", stristr($str, "wor",true); 








?> 


程序 运行 结果 如 图 6-8 所 示 。 





图 6-8 实例 6-12 的 运行 结果 


3. 统计 子 字符 串 出 现 的 次 数 
统计 子 字符 串 出 现 的 次 数 ， 可 以 通过 函数 substr_count() 来 完成 。 函 数 的 语法 格式 如 下 : 
int substr count (string str, string substr,int start,int length) 


函数 功能 :计算 子 字符 串 substr 在 字符 串 str 中 出 现 的 次 数 。 其 中 ，substr 是 区 分 大 小 
写 的 。 
函数 的 参数 说 明 如 表 6-6 所 示 。 


表 6-6 函数 substr_count() 的 参数 说 明 

















参 数 说 明 
str 规定 被 搜索 的 字符 串 
substr 规定 所 搜索 的 字符 串 
start 可 选 。 规 定 在 字符 串 中 何 处 开始 搜索 
len: 可 选 。 规 定 搜索 的 长 度 


【实例 6-13】 使 用 函数 substr_countO 计 算 子 串 出 现 的 次 数 。 


<?php 
header ("content-type:text/html;charset=gb2312"); 
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$str = "line 1,line 2,1ine 3"7 


echo “" 字 符 串 出 现 的 次 数 : ",substr count ($str, "line"); 
BE 


程序 的 运行 结果 如 图 6-9 所 示 。 


lccalhozt/eza=ple_6-16 
人 © |D localhost/example_ 6-16.php 5 
字符 串 出 现 的 次 数 ，3 





6-9 实例 6-13 的 运行 结果 
6.2.4 ”字符 串 替换 函数 


字符 串 蔡 换 函 数 主 要 包括 str_replace( 〇 函数、str_ireplace0 〇 冰 数 、substr_replace() 函 数 和 
strtr() 函 数 。 

(1) str_replace() 函 数 。 

函数 的 语法 格式 如 下 : 

mixed str_replace (mixed find, [mixed replace,]string str, int count) 

函数 功能 :以 区 分 大 小 写 的 方式 将 字符 串 str 中 的 find 字符 串 蔡 换 成 字符 串 replace， 
并 计算 替换 次 数 。 

函数 的 参数 说 明 如 表 6-7 所 示 。 

表 6-7 函数 str_ replace() 的 参数 说 明 


规定 要 查找 的 字符 串 


规定 蔡 换 find 的 值 
规定 被 搜索 的 字符 串 
可 选 。 一 个 统计 蔡 换 次 数 的 变量 











也 


【实例 6-14】 使 用 函数 str_replace() 蔡 换 字符 串 。 


<?php 
header ("Content-Type:text/html;charset=gb2312"); 
$str="hello world"; 
$new_str=str_replace("o","s", $str, $i); 
echo " 普 换 后 的 字符 串 : ", $new_str, "<br/>"; 
echo "替换 的 次 数 : ", $i; 


2> 


程序 的 运行 结果 如 图 6-10 所 示 。 
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localhost/szazpls 6-17 Xx 

和 © |D localhost/example_6-17.php YY 
替换 后 的 字符 串 ， hells wsrld 
蔡 换 的 次 数 : 2 





图 6-10 ”实例 6-14 的 运行 结果 


(2) str_ireplace() 函 数 。 
str_ireplace() 函 数 的 功能 与 str_replace() 函 数 相 同 ， 只 是 str_ireplace0 函 数 不 区 分 大 小 写 。 
【实例 6-15】 使 用 函数 str_ireplace() 蔡 换 字符 串 。 


<?php 
header ("Content-Type:text/html;charset=gb2312"); 
$str=" 学 习 PHP"; 
$new_str=str_ireplace ("php", "JSP 程序 设计 ", $str, $i); 
echo "替换 后 的 字符 串 : ", $new_str, "<br/>"; 
echo "替换 的 次 数 : "， $i; 


?2> 


程序 的 运行 结果 如 图 6-11 所 示 。 


localhost/exasple_6-18 
所 包 |D localhost/example_6-18.php YY 
普 换 后 的 字符 串 ， 学 习 JSP 程 序 设计 


痊 换 的 次 数 ，1 





6-11 ”实例 6-15 的 运行 结果 


(3) substr_replace(O) 函 数 。 
函数 的 语法 格式 如 下 : 
mixed substr replace (mixed str,string replacement,int start,int length) 


函数 功能 : 将 字符 串 str 中 从 start 位 置 到 starttlength 之 间 的 字符 串 蔡 换 为 字符 串 


replacement; 若 没 有 指定 length， 则 从 start 开始 处 蔡 换 到 末尾 。 


函数 的 参数 说 明 如 表 6-8 所 示 。 
表 6-8 函数 substr_replace() 的 参数 说 明 


参 数 描 述 





str 


| 规定 要 检查 的 字符 串 





replacement 规定 要 替换 的 值 
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续 表 





参 数 描 述 
规定 字符 串 开 始 蔡 换 的 位 置 。 

正 数 : 从 字符 串 指定 的 位 置 从 左 向 右 开始 ; 
负数 : 从 字符 串 结尾 指定 的 位 置 开始 ; 

0: 从 字符 串 的 第 一 个 字符 开始 





start 





可 选 。 规 定 要 蔡 换 字符 的 个 数 ， 默 认为 字符 串 的 长 度 。 
正 数 : 被 蔡 换 的 字符 串 长 度 ; 

负数 : 从 字符 串 尾 端 开 始 的 被 蔡 换 字 符 数 ; 

0: 在 指定 的 位 置 插入 字符 串 


【实例 6-16】 使 用 函数 substr_replace() 蔡 换 字符 串 。 


<?php 
header ("Content-Type:text/html;charset=gb2312"); 
$str="studing PHP"; 
$new_str=substr_replace ($str, "JSP", 2); 
echo "替换 后 的 字符 串 : ", $new_str, "<br/>"; 
echo "插入 字符 串 : ", substr_replace ($str," We are ",2,0); 





length 





?> 


程序 的 运行 结果 如 图 6-12 所 示 。 


localhoet/exanple_ 6-19、X 
€ CC Dlocalhost 
和 stJSP 


字符 串 ，st We are uding PHP 





图 6-12 ”实例 6-16 的 运行 结果 


(4) strtr 函数 。 
函数 的 语法 格式 如 下 : 


String strtr (string str, array replacement) 


函数 功能 : 将 字符 串 str 中 的 相应 字符 串 转换 为 数组 replacement 中 的 相应 值 。 
【实例 6-17】 使 用 函数 strtr0 蔡 换 字 符 串 。 


<?php 
header ("Content-Type:text/html;charset=gb2312"); 
$str="studing"; 
$replacement=array ("s"=>"JSP", "g"=>"ASP.NET"); 
$new_str=strtr ($str, $replacement); 
echo "替换 后 的 字符 串 : ", $new_str, "<br/>"; 


2> 


程序 的 运行 结果 如 图 6-13 所 示 。 
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国 1ocalhost/erarple_6-20 x 二 
€ 3 CC BD localhost/example 
蔡 换 后 的 字符 串 ，JSPtudinASP. NET 








图 6-13 ”实例 6-17 的 运行 结果 
6.2.5 比较 字符 串 


字符 串 比 较 函 数 包括 sttcmp(O 函 数 和 strcasecmp() 函 数 。 
(1) stremp0 〇 函数 。 
函数 的 语法 格式 如 下 : 


int strcmp (string strl, string str2) 


函数 功能 :以 区 分 大 小 写 的 方式 比较 字符 串 strl 和 str2。 若 两 个 字符 串 相 等 ， 函 数 返 
回 0， 若 字符 串 strl 大 于 字符 串 st2， 函 数 返 回 大 于 0 的 整数 ， 若 字符 串 strl 小 于 字符 串 
str2， 函 数 返 回 小 于 0 的 整数 。 

【实例 6-18】 使 用 函数 stremp0 〇 比较 字符 串 的 大 小 。 


<?php 
header ("Content-Type:text/html;charset=gb2312"); 
$strl="studing PHP"; 
$str2="study JSP"; 
echo "字符 串 比较 结果 : "; 
if(strcmp($strl, $str2)==0) 
echo "两 个 字符 串 相 等 ! "; 
else 
{ 











if(strcmp ($strl, $str2)>0) 
echo "字符 串 str1> 字 符 串 str2"; 
else 
echo "字符 串 str1< 字 符 串 str2"; 
} 
?> 


程序 的 运行 结果 如 图 6-14 所 示 。 


€ 3 © Dlocalhost/exanple 6-21.php 
字符 串 比较 结果 字符 串 str1) 字 符 串 str2 





6-14 ”实例 6-18 的 运行 结果 
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(2) strcasecmp(O) 函 数 。 
函数 的 语法 格式 如 下 : 
int strcasecmp(string strl, string str2) 


函数 功能 : 与 stremp0 〇 函数 的 功能 相同 ， 只 是 strecasecmp0 函 数 不 区 分 大 小 写 。 
【实例 6-19】 使 用 函数 strcasecmp() 比 较 字 符 串 的 大 小 。 


<?php 
header ("Content-Type:text/html;charset=gb2312"); 
$strl="studing php"; 
$str2="studing jsp"; 
echo "字符 串 比 较 结果 : "; 
if(strcasecmp ($strl, $str2)==0) 
echo "两 个 字符 串 相等 ! "; 
else 
{ 
if(strcmp ($strl, $str2) >0) 
echo "字符 串 str1> 字 符 串 str2"; 
SLse 


echo "字符 串 str1< 字 符 串 str2"; 


有 之 


程序 的 运行 结果 如 图 6-15 所 示 。 


加 :ccalho:t/eza=ple 6-22 x 


€ 3 © |D localhost/exanple_6-22. php 
字符 串 比较 结果 :字符 串 str1) 字 符 串 str2 





6-15 ”实例 6-19 的 运行 结果 


[时 提示 : 车 比较 的 数据 中 包含 的 不 是 字符 串 数据 类 型 ， 则 PHP 会 自动 将 该 数据 转换 
为 字符 囊 数据 类 型 后 再 进行 比较 。 例 如 以 下 程序 中 ， 两 个 数据 比较 的 结果 


是 相等 的 。 

<?php 
$strl="123"; 
$str2=123; 


if(strcmp($strl, $str2)==0) 
echo "两 个 字符 串 相等 ! "; 
else 
{ 
if(strcmp($strl, $str2) >0) 
echo "字符 串 str1> 字 符 串 str2"; 


else 
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echo "字符 串 str1< 字 符 串 str2"; 


2 


6.2.6 去除 字符 串 首尾 空格 和 特殊 字符 


用 户 在 输入 数据 时 ， 若 无 意 中 输入 了 多 余 的 空格 ， 则 需要 去 除 字符 串 两 端 多 余 的 空格 
和 特殊 字符 。PHP 程序 提供 了 ltrim0 函 数 去 除 字符 串 左 端的 空格 和 特殊 字符 、rtrim() 函 数 
去 除 字符 串 右 端的 空格 和 特殊 字符 、trim0 函 数 去 除 字符 串 两 端的 空格 和 特殊 字符 。 


1. Itrim() 函 数 
ltrim0) 函 数 用 于 去 除 字符 串 左 端的 空格 或 指定 字符 串 。 语 法 格式 如 下 : 
string ltrim(string str,string charlist) 
函数 的 参数 说 明 如 表 6-9 所 示 。 
表 6-9 Itrim() 函 数 的 参数 说 明 








参 数 描 述 
str 规定 要 处 理 的 字符 串 
可 选 。 规 定 从 字符 串 中 删除 哪些 字符 。 如 果 省 略 该 参数 ， 则 移 除 下 列 所 有 字符 。 
"0": NULL: 
At": 制 表 符 ; 
charlist "na": 换行 ; 
"x0B": 垂直 制 表 符 ; 
"": 回 车 ; 
"": 空格 
【实例 6-20】 使 用 ltrim0 函 数 去 除 字符 串 左 端的 空格 及 指定 字符 。 
<?php 


header ("Content-Type:text/html;charset=gb2312"); 
$strl=" Hello nn 

$str2="worldwo"; 

echo "去 除 字 符 串 1 左 端 空格 : ", ltrim($str1), "<br/>"; 
echo "去 除 字符 串 2 左 端的 字符 wo: ",1trim($str2, "wo"); 


受奖 


程序 的 运行 结果 如 图 6-16 所 示 。 


园 jccaahostr/ezasple 6- 
€ 


@ | D localhost/example_6- 


去 除 字符 串 1 左 端 空格 ，Hello 
去 除 字符 串 2 左 端的 字符 wo: rl1dmo 





6-16 ”实例 6-20 的 运行 结果 
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2. rtrim() 函 数 


rtrim0) 函 数 用 于 去 除 字符 串 右 端的 空格 或 指定 字符 串 。 语 法 格式 如 下 : 


string rtrim(string str,string charlist) 


该 函数 的 参数 与 lrim0 函 数 参 数 的 含义 大 致 相同 。 
【实例 6-21】 使 用 rtrim0 函 数 去 除 字符 串 右 端的 空格 及 指定 字符 。 


<?php 
header ("Content-Type:text/html;charset=gb2312"); 
$strl="Hello a 
$str2="world"; 
echo "去 除 字 符 串 1 右 端 空格 : ", rtrim($str1)，, $str2,"<br/>"; 
echo "去 除 字符 串 2 尾部 字符 : " ,rtrim($str2,"d"); 


> 


序 的 运行 结果 如 图 6-17 所 示 。 


蜗 
[ail 


localhost/exaple_6-2 
€ © | BD localhost/example_6-24. php 
去 除 字符 串 1 右 端 空格 ， Helloworld 


去 除 字符 串 2 尾部 字符 ，worl 





图 6-17 实例 6-21 的 运行 结果 
3. trim() 函 数 
trim(0) 函 数 用 于 去 除 字符 串 两 端的 空格 或 指定 字符 串 。 语 法 格式 如 下 : 


string trim(string str,string charlist) 


该 函数 参数 的 含义 与 lrim0 函 数 参数 的 含义 相同 。 
【实例 6-22】 使 用 trim0 函 数 去 除 字符 串 两 端的 空格 及 指定 字符 。 


<?php 
header ("Content-Type:text/html;charset=gb2312"); 
$strl=" Hello nr 
$str2="worldwo"; 
echo "去 除 字符 串 1 两 端 空格 : ", trim($str1), "<br/>"; 
echo "去 除 字符 串 2 两 端的 字符 : ", trim($str2, "wo"); 


Bs 


程序 的 运行 结果 如 图 6-18 所 示 。 
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localhozt/ezasple_6-25 


去 除 字符 串 1 两 端 空格 : Hello 


去 除 字符 串 2 两 端的 字符 ; r1d 





6-18 ”实例 6-22 的 运行 结果 
6.2.7 ”字符 串 与 HTML 相互 转换 


PHP 字符 串 与 HIML 之 间 的 转换 主要 利用 函数 htmlentities()、htmlspecialchars() 和 
strip_tags() 来 完成 。 

1. htmlentities() 函 数 

函数 的 语法 格式 如 下 : 


string htmlentities (string str, int quote style,string charset,bool 
encode) 


函数 功能 :htmlentities0 函 数 将 所 有 的 字符 转换 为 HTML 字符 串 。 
函数 的 参数 说 明 如 表 6-10 所 示 。 
表 6-10 ”htmlentities() 函 数 的 参数 说 明 





参 数 描 述 
str 规定 要 转换 的 字符 串 
可 选 。 选 择 处 理 字符 串 中 引号 的 方式 ， 有 3 个 值 可 选 : 
ENT_COMPAT， 为 默认 值 ， 只 转换 双 引 号 ， 忽 略 单 引号 ; 
ENT_NOQUOTES， 忽 上 略 双 引号 和 单 引号 ; 


ENT_ QUOTES， 转 换 双 引号 和 单 引 号 


quote_style 


charset 可 选 。 规 定 转换 所 使 用 的 字符 集 ， 默 认为 ISO-8859-1 
可 选 。 规 定 是 否 编码 已 存在 的 HIML 实体。 
encode TRUE: 默认 ， 对 每 个 实体 进行 转换 ; 





FALSE: 不 会 对 已 存在 的 HTML 实体 进行 转换 
【实例 6-23】 使 用 htmlentities0 函 数 对 字符 串 进行 转换 。 


<?php 
header ("Content-Type:text/html;charset=gb2312"); 
$str='<table width="300" border="1"” ></table>'; 
echo "转换 结果 : ", htmlentities ($str,ENT_QUOTES); 
2 


程序 的 运行 结果 如 图 6-19 所 示 。 
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exasple_ 6-26. Xx 


© DB localhost/exanple 6-26.php 名) 三 


转换 结果 ;<table width=”300” border="1” >《/table> 





图 6-19 实例 6-23 的 运行 结果 
2. htmlspecialchars() 函 数 
函数 的 语法 格式 如 下 : 
string htmlspecialchars (string str,int quote style,string charset,bool encode) 


函数 功能 : htmlspecialchars() 函 数 能 将 字符 串 中 的 某 些 特殊 字符 转换 为 对 应 的 预定 义 
实体 。 

htmlspecialchars() 函 数 的 参数 含义 与 htmlentities() 函 数 的 参数 含义 相同 。 

htmlspecialchars() 函 数 能 够 转换 的 特殊 字符 如 表 6-11 所 示 。 


表 6-11 htmlspecialchars() 函 数 能 够 转换 的 特殊 字符 





对 应 的 HTML 或 XML 文档 中 的 特殊 字符 对 应 的 预定 义 实 体 





【实例 6-24】 使 用 htmlspecialchars0 函 数 转换 字符 串 中 的 特殊 字符 。 


<?php 
header ("Content-Type:text/html;charset=gb2312"); 
$str = "This is some <b>bold</b> text."; 
echo "转换 前 : ", $str, "<br/>"; 
echo "转换 后 : ", htmlspecialchars ($str); 
?> 


程序 的 运行 结果 如 图 6-20 所 示 。 





localhost /exzasple_6-27 
i @ | D localhost/example_6-27. php 


转换 前 ，This is some bold text. 


转换 后 ，This is some 《b>bold</b> text. 





6-20 ”实例 6-24 的 运行 结果 
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3. strip_tags() 函 数 
函数 的 语法 格式 如 下 : 
string strip tags(string str,string allow) 


函数 功能 ，strip_tags() 函数 去 除 字 符 串 中 的 HTML、XML 以 及 PHP 的 标签 。 
strip_tags() 函 数 的 参数 说 明 如 表 6-12 所 示 。 


表 6-12 strip_tags() 函 数 的 参数 说 明 





参 数 说 明 
str 规定 要 检查 的 字符 串 
allow, 可 选 。 规 定 运 行 的 标签 ， 这 些 标签 不 会 被 删除 


【实例 6-25】 使 用 strip_tags0 函 数 转换 字符 串 中 的 特殊 字符 。 
<?php 

$str="Hello <b><i>world!</i></b>"; 

echo strip_tags ($str,"<b>"); // 去 除 HTML 标签 ， 但 允许 使 用 <b> 
?> 


程序 的 运行 结果 如 图 6-21 所 示 。 





© BD localhost 


Hello world! 





图 6-21 实例 6-25 的 运行 结果 


6.2.8 连接 与 分 割 字符 串 





字符 串 的 连接 和 分 割 函数 包括 implode() 函 数 、explode() 函 数 和 strtok0) 函 数 。 
1. implode() 函 数 

函数 的 语法 格式 如 下 : 

string implode (string str,array arr) 

函数 功能 :使 用 字符 串 str 将 数组 arr 中 的 元 素 连接 成 一 个 字符 串 。 

【实例 6-26】 使 用 函数 implode0 连 接 字符 串 


<?php 
$a=array ("Www", "sina", "com"); 
echo implode(".",$a); 





o 


Bs 


程序 的 运行 结果 如 图 6-22 所 示 。 
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localhoat/exasple_6-29 


€ 3 © |D localhost/exam 


ww. sina. com 





图 6-22 实例 6-26 的 运行 结果 


2. explode() 函 数 
函数 的 语法 格式 如 下 : 
array explode (string seprator, string str,int limit) 
函数 功能 ， 将 字符 串 分 散 为 数组 。 
函数 的 参数 说 明 如 表 6-13 所 示 。 
表 6-13 函数 explode() 的 参数 说 明 


参 数 说 明 
seprator 规定 分 割 字符 串 的 符号 
str 规定 要 分 割 的 字符 串 
可 选 。 规 定 要 返回 的 数组 元 素 的 数目 。 
ait 大 于 0: 返回 包含 最 多 limit 个 元 素 的 数组 ; 


小 于 0: 返回 包含 除了 最 后 的 -limit 个 元 素 以 外 的 所 有 元 素 的 数组 ; 
0; 返回 包含 一 个 元 素 的 数组 


【实例 6-27】 使 用 函数 explode0 分 割 字 符 串 。 


<?php 
$str ="one, two, three, four"; 
print_r(explode(",",$str,0)); // limit 为 0 
echo "<br/>"; 
print re(explodal(" ny Sater2))e /A Timit 大 于 必 
echo "<br/>"s 
print_r(explode(",",$str,-1)); // limit 小 于 0 





2> 


程序 的 运行 结果 如 图 6-23 所 示 。 


BD localhost/example_6-30. php 


Array ( [0] => one, two, three, four ) 


Array ( [0] => one [1] => two, three, four ) 
Array ( [0] => one [1] => two [2] => three ) 





6-23 ”实例 6-27 的 运行 结果 
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3. strtok() 函 数 

函数 的 语法 格式 如 下 : 

string strtok(string str,string seprator) 

函数 功能 : 使 用 字符 串 seprator 对 字符 串 str 进行 一 次 分 割 ， 也 可 以 连续 调用 函数 进行 
多 次 分 割 。 第 一 次 使 用 函数 时 ， 需 要 指定 参数 str; 以 后 再 调用 时 ， 不 需要 再 指定 参数 
str。 


函数 的 参数 说 明 如 表 6-14 所 示 。 








表 6-14 函数 strtok() 的 参数 说 明 








规定 要 分 割 的 字符 串 

规定 分 割 字符 串 的 字符 
【实例 6-28】 使 用 函数 strtok0 分 割 字符 串 。 
<?php 


$string = "Hello world. Beautiful day today."; 
$str = strtok($string，" "); // 使 用 空格 分 割 字 符 串 
while ($str != false) 
{ 
echo "$str<br>"; 
Sstr = strtok(™ ™“)» 
] 
> 


程序 的 运行 结果 如 图 6-24 所 示 。 





localhost 


Hello 


world. 
Beautiful 
day 
today. 





6-24 ”实例 6-28 的 运行 结果 
6.3 ”综合 实 训 案例 


本 节 主 要 介绍 利用 字符 串 处 理 的 有 关 函 数 进行 超 长 文本 分 页 显示 的 方法 和 步 又。 
1. 分 析 


首先 定义 两 个 自 定 义 函 数 : unhtml($str) 和 msubstr($str)。 其 中 ， 函 数 unhtml0 的 功能 就 
是 将 文本 中 的 一 些 特殊 字符 转换 为 HTML 标记 符号 ; msubstr0 函 数 的 功能 就 是 根据 设 定 篇 
幅 的 长 度 对 文本 进行 分 页 截取 。 另 外 还 需要 对 文本 进行 相应 的 计算 。 
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每 页 显示 的 字 节 数 (char_size): 如 每 页 显示 500 个 字 节 ，$char size=500。 
文本 总 字 节 数 ($length): strlen(unhtml($counter))。 
总 页 数 (page_count): 


$page_count=ceil ($length/$char size); 


一 页 的 字 节 数 : 
msubstr ($counter, 0, ($_GET['page']-1)*$char size); 
下 一 页 的 字 节 数 : 

msubstr ($counter, 0,$_GET['page']*$char size); 
当前 页 显示 的 文本 : 





substr($c1,strlen($c),strlen($c1)-strlen ($c)); 


程序 的 运行 结果 如 图 6-25 所 示 。 


© 口 localhost/fenye. php 


超 长 文本 分 页 示例 


| 必 霹 ，。 为 二 基地 生 这 辑 刷 绩 和 创新 误 力 ， 和 天 惠 
网 ， 通 过 各 种 才学 方式 和 手机 学 生 的 








| 险 ， 发 现 问 题 ， 提 出 问题 ， 设计 举例 

rt 衣 是 人 人 可是 和， 本 再 给 出 算法 ， 
最 后 编写 出 完整 的 程序 ， 而 在 这 最 关键 的 是 每 一 步 都 采用 与 学 生 一 起 探 
| 时 的 让 学 生 在 启发 下 思考 ， 从 而 掌握 独立 分 析 问 题 、 解 决 
问题 的 方法 。 二 和 修了 公司 推测 的 纺 委 轩 央企 业 庆 除了 堂 实 


页 次 ，1 /4 页 分 页 首页 上 一 页 下 一 页 屋 页 


























6-25” 超 长 文本 分 页 显示 


2. 程序 代码 
创建 PHP 程序 文件 function.php， 包 含 两 个 自 定义 函数 unhtml0 和 msubstr0， 程 序 代 


码 如 下 : 


<?php 
function unhtml ($content){ 


} 


$content=htmlspecialchars ($content); 
$content=str_replace (chr (13), "<br/>", $content); 
$content=str_ replace(" ","é&gnbsp;",$content); 
return trim($content); 


function msubstr ($str, $start, $len) 


$strlen=$start+$len; 
$tmpstr=""; 
for ($i=0; $i<$strlen; $i++) 
{ 
if(ord(substr ($str, $i,1))>0xa0){ 
// 如 果 字符 的 AScII 序数 值 大 于 0xa0, 则 表示 为 汉字 
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$tmpstr=$tmpstr.substr ($str, $i,2); 
$i++7 
}elsef 
$tmpstr= $tmpstr.substr ($str, $i,1); 
} 
return $tmpstr; 


: 
> 
创建 PHP 程序 文件 fenye.php， 程 序 代 码 如 下 
<?php 
require once ("function.php"); // 调 用 自 定义 函数 文件 
header ("Content-Type:text/html;charset=gb2312"); 
if (!isset($ GET['page'])) 
{ 
$_GET['page']=1; 
} 
$char_size=500; // 每 页 显示 的 字 节 数 
?> 
<html> 
<head> 


<meta http-equiv="Content-Language" content="zh-cn"> 
<meta http-equiv="Content-Type" content="text/html; charset=gbk"> 
<title 分 页 显示 </title> 
</head> 
<body> 
<table border="1" width="100%"> 
<tr> 
<td><p align="center"> 长 文本 分 页 示例 </td> 
</tr> 
<tr> 
<td> 
<?php 
$counter=file get_contents ("file.txt"); // 读 取 文 本 文件 
$length=strlen (unhtml ($counter)); // 获 取 文 本 文件 的 长 度 
$page_count=ceil ($length/$char size); // 计 算 总 页 数 
$c=msubstr ($counter,0, ($_GET['page']-1)* $char size); 
$cl=msubstr ($counter, 0,$_GET['page']* $char size); 
echo substr($c]1,strlen($c),strlen($c1)-strlen ($c)); 
?> 
</td> 
</tr> 
EE 
<td> 
<p align="center"> 页 次 : <?php echo $_GET["page"]; ?> 
/ <?php echo $page_count;?> 页 &nbsp; &nbsp; &nbsp; 分 页 : 
<?2php 
if($_GET['page']){ 
echo "<a href=fenye.php?page=1> 首 页 </a>gnbsp;"; 
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echo "<a href—fenye.php?page=". ($_GET["page']-1) ."> 上 — 页 </a>g&nbsp; "; 
} 
if($_GET['page']<$page count){ 
echo "<a href=fenye.php?page=". ($_GET['page']+1) ."> 下 一 页 </a>g&nbsp;"; 
echo "<a href=fenye.php?page=".$page count."> 尾 页 </a>"; 
} 
> 
</td> 
</tr> 
</table> 
</body> 
</html> 


本 章 小 结 


本 章 详细 介绍 了 字符 串 操 作 的 相关 函数 ， 包 括 获取 字符 串 的 长 度 函数 、 截 取 字 符 串 函 
数 、 蔡 换 字符 串 函数 、 比 较 字 符 串 函数 、 连 接 和 分 割 字 符 串 函数 等 。 


习 题 


1. 计算 如 图 6-26 所 示 提 交 文 字 的 长 度 。 


所 © Dlocalhost/li. htn 


[再 明 时 节 雨 纷纷 ， 路 上 行人 欲 断 更 。 
借 问 洒 家 何 处 有 ， 牧 重 禹 指 可 花村 。 








图 6-26 ”提交 文字 


2. 实现 字符 串 的 反 转 功能 。 
3. 编写 程序 ， 获 取 文 件 的 扩展 名 。 如 文件 registerlog， 扩 展 名 为 log。 
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本 章 要 点 
@ ”PHP 程序 中 表单 数据 采集 的 方法 
学 习 目标 
@ 掌握 PHP 程序 中 数据 采集 的 方法 


7.1 表单 数据 采集 





7.1.1 表单 
1. 表单 属性 
表单 常用 的 属性 有 : name、id、title、action、method、enctype 等 。 表 单 属性 的 描述 如 
表 7-1 所 示 。 
表 7-1 表单 属性 
属 性 说 明 
name 表单 的 名 称 
id 表单 的 id 号 
title 表单 的 标题 


method 表单 数据 提交 的 方式 ， 包 括 GET 和 POST 两 种 方式 ， 默 认为 GET 
action 将 表单 中 的 数据 “提交 ”的 目的 地 址 。 车 为 空 ， 则 提交 给 当前 文件 


设置 提交 表单 数据 时 的 编码 方式 ， 包 括 multipart/form-data 和 application/x-www-form- 
YP。 | urlencoded。 若 表单 中 存在 文件 上 传 框 ， 必 须 将 enctype 属性 设置 为 multiparyfomm-data 








target 用 来 指定 目标 窗口 
2. 创建 表单 
通过 使 用 HTML 标签 <formm> 和 </formm> 来 创建 表单 的 开始 和 结束 位 置 ， 其 中 可 以 包含 
若干 个 元 素 。 
【实例 7-1】 编 辑 my_form html 文件 ， 在 该 文件 中 创建 表单 标签 。 


<form title=" 我 的 表单 " method="POST" action=""> 
我 的 表单 


</form> 


该 文件 的 运行 结果 如 图 7-1 所 示 。 
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图 7-1 实例 7-1 表单 标签 运行 结果 


7.1.2 ”表单 控件 

表单 创建 完成 后 ， 就 可 以 在 表单 标签 <form> 和 </form> 之 间 添 加 表单 控件 来 采集 浏览 
器 的 数据 。 表 单 控件 包括 : 文本 框 、 文 本 域 、 复 选 框 、 单 选 按钮 、 文 件 上 传 框 和 下 拉 列 表 
框 等 。 

1. 文本 框 

文本 框 是 一 种 让 用 户 输入 内 容 的 表单 控件 ， 通 常用 来 输入 简单 的 单行 信息 ， 如 用 户 
名 、 邮 箱 地 址 、 登 录 密码 等 。 

















代码 格式 : 
<input type="text" name=".." size=".." maxlength=".." value="." /> 
文本 框 的 属性 说 明 如 表 7-2 所 示 。 
表 7-2 文本 框 的 属性 
说 明 


定义 文本 框 的 类 型 。 值 可 以 取 text、password。 若 为 text， 则 显示 输入 的 内 容 ， 若 为 
assword， 则 输入 的 内 容 均 显示 为 *， 一 般 应 用 于 输入 登录 密码 
文本 框 的 名 称 
定义 文本 框 的 宽度 ， 默 认为 20 
定义 输入 字符 的 最 大 数量 
文本 框 显示 的 初始 值 
【实例 7-2】PHP 程序 采集 文本 框 的 数据 。 
创建 静态 网 页 文件 texthtml， 在 文件 中 创建 表单 标签 ， 并 在 表单 标签 内 添加 两 个 文本 
框 控 件 。 文 本 框 控件 的 属性 如 表 7-3 所 示 。 
表 7-3 实例 7-3 文 本 框 的 属性 























属 性 文本 框 2 
type password 
name login password 
size 20 
maxlength 20 
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text.html 文件 代码 如 下 : 


<html> 
<head> 
<meta http-equiv="Content-Language" content="zh-cn"> 
</head> 
<body> 
<form method="POST" action="login.php"> 
<p> 用 户 名 : <input type="text" name="login name" size="20" 
maxlength="20" /></p> 
<p> 密 码 : <input type="password" name="login password" size="20" 
maxlength="20" /></p> 
<p><input type="submit" value=" 提 交 " name="Bl"><input type="reset" 
value=" 重 置 " name="B2"></p> 
</form> 
</body> 
</html> 


text.html 文件 打开 后 ， 分 别 在 两 个 文本 框 内 输入 用 户 名 和 密码 ， 最 后 再 单 击 “ 提 交 ” 
按钮 ， 如 图 7-2 所 示 。 





7-2 ”txt.html 文件 显示 结果 


创建 login.php， 用 于 接收 text.html 文件 中 文本 框 控件 的 数据 ， 程 序 代码 如 下 : 


<?php 
header ("Content-Type:text/html;charset=gb2312"); 
echo "用 户 名 : ",$_POST["login name"], "<br/>"; 
echo "密码 : ",$_POST["login_password"], "<br/>"; 
ee 


text.html 文件 提交 后 的 运行 结果 如 图 7-3 所 示 。 


国 1ocalhost/1loein php x 全 
所 © DD localhost 


用 户 名 ，john 


密码 :abc123 





7-3 ”实例 7-2 数据 提交 结果 


.104 1， 














2. 文本 域 
文本 域 是 一 种 多 行 的 文本 框 ， 能 够 让 用 户 输入 较 长 的 文字 信息 。 代 码 格式 如 下 : 
<textarea name=".." COlS=".." roOWws=".." >content</textarea> 
文本 域 的 属性 说 明 如 表 7-4 所 示 。 
表 7-4 文本 域 的 属性 
属 性 说 明 
name 文本 域 的 名 称 
cols 定义 文本 域 的 宽度 
IOWS 定义 文本 域 的 高 度 
content 定义 文本 域 显示 的 文字 内 容 





【实例 7-3】PHP 程序 采集 文本 域 的 数据 。 
创建 静态 网 页 文件 textarea.html， 在 文件 中 创建 表单 标签 ， 并 在 表单 标签 内 添加 一 个 
文本 域 控 件 。 文 本 域 控件 的 属性 如 表 7-5 所 示 。 
表 7-5 实例 7-3 文 本 域 的 属性 





textarea.html 文件 代码 如 下 : 


<html> 

<head> 

<meta http-equiv="Content-Type" content="text/html; charset=gb2312"> 

<title> 文 本 区 实例 </title> 

</head> 

<body> 

<form method="POST" action="show text.php"> 
<textarea name="text" cols="60" rows="]14"></textarea><br> 
<input type="submit" value=" 提 交 " name="Bl"><input type="reset" 

value=" 重 置 " name="B2"> 

</form> 

</body> 

</html> 


textarea.html 文件 打开 后 ， 在 文本 域内 输入 字符 ， 最 后 再 单 击 “提交 ”按钮 ， 如 图 7-4 
所 示 。 
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© DD localhost/textarea. html 





| 明月 几时 有 ， 把酒 问 青天 | 





7-4 textarea.html 文件 显示 结果 


创建 show_textphp， 用 于 接收 textarea.html 文件 中 文本 域 控件 的 数据 ， 程 序 代码 如 下 : 


<?php 
header ("Content-Type:text/html;charset=gb2312"); 
$content=$_POST["text"]; 
echo $content; 


textarea.html 文件 数据 提交 后 ， 运 行 结果 如 图 7-5 所 示 。 
国 1ocalhost/shor_tert. chp x We 


€ © 口 localhost 
明月 几时 有 ， 把 酒 问 青 天 





图 7-5 实例 7-3 数据 提交 后 的 运行 结果 
3. 复 选 框 
复 选 框 用 来 在 浏览 器 上 为 用 户 提供 一 些 选 项 ， 用 户 可 从 中 任意 选择 。 其 代码 格式 如 下 : 
<input type="checkbozx" name=".." value=".." [checked] /> 
复 选 框 的 属性 说 明 如 表 7-6 所 示 。 
表 7-6 复 选 框 的 属性 


属 性 说 明 
定义 复 选 框 的 名 称 





定义 复 选 框 的 值 
可 选 。 定 义 初始 状态 下 复 选 框 是 否 被 选中 





【实例 7-4】PHP 程序 采集 复 选 框 的 数据 。 
创建 网 页 文件 checkbox.html， 在 文件 中 创建 表单 标签 ， 并 在 表单 标签 内 添加 三 个 复 选 
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框 控件 。 复 选 框 控件 的 属性 如 表 7-7 所 示 。 
表 7-7 实例 7-4 复 选 框 的 属性 











checkbox.html 文件 代码 如 下 : 


<html> 

<head> 

<meta http-equiv="Content-Language" content="zh-cn"> 

<meta http-equiv="Content-Type" content="text/html; charset=gb2312"> 

<title> 复 选 框 实例 </title> 

</head> 

<body> 

<form method="POST" action="show_checkbox.php"> 
<input type="checkbox" name="chkl" value=" 音 乐 "> 音乐 <p> 
<input type="checkbox" name="chk2" value=" 旅 游 "> 旅游 <p> 
<input type="checkbox" name="chk3" value=" 体 育 "> 体 育 <p> 
<input type="submit" value=" 提 交 " name="B1"> 

<input type="reset" value=" 重 置 " name="B2"> 

</form> 

</body> 

</html> 


checkbox.html 文件 打开 后 在 复 选 框 间 任意 选择 ， 最 后 再 单 击 “提交 ”按钮 ， 如 图 7-6 
所 示 。 


localhost 





7-6 ”checkbox.html 文件 显示 结果 


创建 show_checkbox.php， 用 于 接收 checkbox.html 中 复 选 框 控件 chkl、chk2、chk3 的 
数据 ， 程 序 代 码 如 下 : 


<?php 
header ("Content-Type:text/html;charset=gb2312"); 
if(isset($_POST["chk1"])) // 判 断 是 否 传递 了 chkl 的 值 
echo "你 选择 了 ".S_POST ["chkl"] ."<br/>"; 
if(isset ($_POST["chk2"])) // 判 断 是 否 传递 了 chk2 的 值 
echo "你 选择 了 ".S_POST ["chk2"] ."<br/>"; 
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if(isset($ POST["chk3"])) // 判 断 是 否 传递 了 chk3 的 值 
echo "你 选择 了 ".$_POST["chk3"] ."<br/>"; 
> 


checkbox.html 文件 数据 提交 后 的 运行 结果 如 图 7-7 所 示 。 


国 1cealhost/shor_chee 
人 © 口 localhost 


你 选择 了 音乐 
你 选择 了 体育 





7-7 ”实例 7-4 数据 提交 后 的 运行 结果 


号 提 示 :  。 由 于 用 户 可 以 任意 选择 复 选 框 项 目 ， 因 此 在 PHP 程序 中 要 想 接收 复 选 框 
的 值 ， 需 要 使 用 isset(0) 函 数 判 断 复 选 框 的 值 是 否 被 传递 过 来 。 
@ isset($var) 函 数 用 来 判断 变量 $var 是 否 被 设置 过 。 若 变量 不 存在 ， 则 返回 
FALSE; 若 变量 存在 且 其 值 为 NULL， 也 返回 FALSE; 若 变量 存在 且 值 
不 为 NULL， 则 返回 TURE。 
选择 项 目 比较 多 的 时 候 ， 复 选 框 也 可 以 采用 数组 命名 的 方式 来 传递 值 。 
【实例 7-$】 复 选 框 以 数组 命名 的 方式 来 传递 数据 。 
创建 网 页 文件 checkbox.html， 在 文件 中 创建 表单 标签 ， 并 在 表单 标签 内 添加 三 个 复 选 
框 控件 。 复 选 框 控件 的 属性 如 表 7-8 所 示 。 


表 7-8 实例 7-5 复 选 框 的 属性 





checkbox.html 文件 代码 如 下 : 


<html> 

<head> 

<meta http-equiv="Content-Language" content="zh-cn"> 

<meta http-equiv="Content-Type" content="text/html; charset=gb2312"> 

<title> 复 选 框 实例 </title> 

</head> 

<body> 

<form method="POST" action="show_checkbox.php"> 
<input type="checkbox" name="chk[]"” value=" 音 乐 "> 音乐 <p> 
<input type="checkbox" name="chk[]"” value=" 旅 游 "> 旅游 <p> 
<input type="checkbox" name="chk[]"” value=" 体 育 "> 体 育 <p> 
<input type="submit" value=" 提 交 " name="B1"> 

<input type="reset" value=" 重 置 " name="B2"> 
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</form> 

</body> 

</html> 

创建 show_checkbox php， 用 于 接收 checkbox.html 中 复 选 框 控 件 的 数据 ， 程 序 代码 如 下 : 
<?php 


header ("Content-Type:text/html;charset=gb2312"); 
for ($i=0;$i<count ($_POST["chk"]);$i++) { 
echo "你 选择 了 ".$_POST["chk"] [$i]; 


?> 

4. 单 选 按钮 

单 选 按钮 是 在 浏览 器 上 让 用 户 在 若干 个 选项 中 选择 其 中 一 个 项 目 。 其 代码 格式 如 下 : 
<input type="radio" name=".." value=".." [checked] /> 





单 选 按钮 的 属性 说 明 如 表 7-9 所 示 。 
表 7-9 单 选 按钮 的 属性 





属 性 说 明 
name, 定义 单 选 按钮 的 名 称 
value 定义 单 选 按钮 的 值 
checked 可 选 。 定 义 初始 状态 下 单 选 按钮 是 否 被 选中 


【实例 7-6】PHP 程序 采集 单 选 按钮 的 数据 。 
创建 网 页 文件 radiohtml， 在 文件 中 创建 表单 标签 ， 并 在 表单 标签 内 添加 三 个 单 选 按钮 
控件 。 单 选 按钮 控件 的 属性 如 表 7-10 所 示 。 
表 7-10 实例 7-6 单 选 按钮 的 属性 


name 


Value 


radio .html 文件 代码 如 下 : 


<html> 

<head> 

<meta http-equiv="Content-Language" content="zh-cn"> 

<meta http-equiv="Content-Type" content="text/html; charset=gb2312"> 

<title> 单 选 钮 实例 </title> 

</head> 

<body> 

<form method="POST" action="show_radio.php"> 
<input type="radio" name="radiol" value=" 北 京 "> 北京 <p> 
<input type="radio" name="radiol" value=" 上 海 "> 上 海 <p> 
<input type="radio" name="radiol" value=" 广 州 "> 广州 <zp> 
<input type="submit" value=" 提 交 " name="B1"> 
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<input type="reset" value=" 重 置 " name="B2"> 
</form> 
</body> 
</html> 


radio.html 文件 打开 后 在 单 选 按钮 间 任 选 一 项 ， 最 后 再 单 击 “ 提 交 ” 按 钮 ， 如 图 7-8 








7-8 radio.html 文件 显示 结果 


创建 show_radio php， 用 于 接收 radio.html 中 单 选 按钮 控件 的 数据 ， 程 序 代 码 如 下 : 


<?php 
header ("Content-Type:text/html;charset=gb2312"); 
if(isset($_POST["radiol1"])) 
echo "你 选择 了 ".S_POST["radiol"] ."<br/>"; 
区 


radio.html 文件 数据 提交 后 的 运行 结果 如 图 7-9 所 示 。 


BD localhost/show radio.php 3 


你 选择 了 上 海 





7-9 实例 7-6 数据 提交 的 运行 结果 


于 提示 :  。 具有 相同 名 称 的 单 选 按 钮 为 一 组 ， 一 组 单 选 按 钮 中 只 能 选择 一 项 。 
e@ 若 单 选 按钮 中 初始 状态 下 有 一 个 处 于 选中 状态 ， 则 在 PHP 程序 中 可 以 不 
使 用 isset() 函 数 ; 若 初始 状态 下 没有 单 选 按 钮 处 于 选中 状态 ， 则 在 PHP 
程序 中 必须 使 用 isset() 函 数 来 判断 单 选 按钮 的 值 是 否 被 传递 过 来 。 
5. 下 拉 列 表 杠 
下 拉 列 表 框 是 让 用 户 在 一 系列 下 拉 选 项 中 选择 项 目的 控件 ， 分 为 单 选 下 拉 列 表 框 和 多 
选 下 拉 列 表 框 。 其 代码 格式 如 下 : 


<select name=".." size="." [multiple]> 
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<option value: 
<option value: 


--" [selected]>...</option> 
>...</option> 








Ed ee 
下 拉 列 表 框 的 属性 说 明 如 表 7-11 所 示 。 
表 7-11 下 拉 列 表 框 的 属性 








属 性 说 明 
name 定义 下 拉 列 表 框 的 名 称 
size 定义 下 拉 列 表 框 的 高 度 





可 选 。 定 义 下 拉 列 表 框 是 单 选 还 是 多 选 ， 默 认为 单 选 。 当 为 多 选 时 ， 在 按 住 Ctrl 键 


tls 的 同时 ， 单 击 选择 项 可 进行 多 选 ， 或 者 按 住 Shift 键 单 击 连续 多 先 

定义 下 拉 列 表 框 每 个 选项 的 值 ， 若 没有 定义 该 属性 ， 则 选项 的 值 为 <option> 和 
T </option> 之 间 的 内 容 
ee 可 选 。 定 义 下 拉 列 表 框 的 选项 在 初始 状态 下 是 否 为 选中 状态 ， 一 个 下 拉 列 表 框 中 只 





能 有 一 个 选项 处 于 选中 状态 


【实例 7-7】 用 PHP 程序 采集 下 拉 列 表 框 的 数据 。 
创建 网 页 文件 list.html， 在 文件 中 创建 表单 标签 ， 并 在 表单 标签 内 添加 一 个 下 拉 列 表 
框 控件 。 下 拉 列 表 框 控件 的 属性 如 表 7-12 所 示 。 
表 7-12 实例 7-7 下 拉 列 表 框 控件 的 属性 


name 


value Visual Basic，PHP，C 语言 





listhtml 文件 代码 如 下 : 


<html> 
<head> 
<meta http-equiv="Content-Language" content="zh-cn"> 
<meta http-equiv="Content-Type" content="text/html; charset=gb2312"> 
<title> 单 选 钮 实例 </title> 
</head> 
<body> 
<form method="POST" action="show_ list.php"> 
<select size="5" name="]listl" > 
<option value="Visual Basic">Visual Basic</option> 
<option value="PHP">PHP</option> 
<option value="C 语言 ">C 语言 </option> 
</select></br> 
<input type="submit" value=" 提 交 " name="B1"> 
<input type="reset" value=" 重 置 " name="B2"> 
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</form> 
</body> 
</html> 


list.html 文件 打开 后 在 下 拉 列 表 框 中 任 选 一 项 ， 最 后 再 单 击 “ 提 交 ” 按 钮 ， 如 图 7-10 


所 示 。 


D localhost/list 


Visual Basic ~ 
C 语 计 


| 提交 | 重 轩 | 





7-10 listhtml 文件 显示 结果 


创建 show_listphp， 用 于 接收 listhtml 中 下 拉 列 表 框 控件 的 数据 ， 程 序 代码 如 下 


<?php 
header ("Content-Type:text/html;charset=gb2312"); 
echo "你 选择 了 ".$_POST["1list1"]."<br/>"; 

?> 





7-11 实例 7-6 数据 提交 后 的 运行 结果 


[对 提示 : ”当下 拉 列 表 框 为 多 选 时 ， 可 以 将 下 拉 列 表 框 的 name 定义 为 数组 形式 . 在 
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PHP 程序 中 采用 数组 的 方式 采集 下 拉 列 表 框 的 数据 ， 此 时 listhtml 文件 中 下 
拉 列 表 框 的 定义 语句 可 以 写 为 

<select size="5" name="1listl[]"”multiple> 

则 PHP 程序 代码 可 以 写 为 


<?php 
header ("Content-Type:text/html;charset=gb2312"); 
echo "你 选择 了 : <br/>"; 
for ($i=0;$i<count ($_POST["l1ist1"]);$i++) 
echo $_POST["list1"] [$i]."<br/>"; 
ES 


sr we 


6. 文件 上 传 框 
文件 上 传 框 是 用 户 在 上 传 文件 时 用 来 选择 文件 的 控件 。 其 代码 格式 如 下 : 


<input type="file" name=".." size=".." maxlength=".." /> 
文件 上 传 框 的 属性 说 明 如 表 7-13 所 示 。 
表 7-13 文件 上 传 框 的 属性 











属 性 说 明 
i | 定义 文件 上 传 框 的 名 称 
i | 可 选 。 定义 文件 上 传 框 的 宽度 
二 可 选 。 定 义 文件 上 传 框 最 多 输入 的 字符 数 











【实例 7-8】 用 PHP 程序 采集 文件 上 传 框 的 数据 。 
创建 网 页 文件 file .html， 在 文件 中 创建 表单 标签 ， 并 在 表单 标签 内 添加 一 个 文件 上 传 
框 控件 。 文 件 上 传 框 控件 的 属性 如 表 7-14 所 示 。 


表 7-14 实例 7-7 文件 上 传 框 的 属性 














属 性 说 明 
name 
Size 
maxlength 
file.html 文件 代码 如 下 : 
<html> 
<head> 


<meta http-equiv="Content-Language" content="zh-cn"> 
<meta http-equiv="Content-Type" content="text/html; charset=gb2312"> 
</head> 
<body> 
<form method="POST" action="show_file.php" > 
<input type="file" name="my_file" size="40" maxlength="100"></br> 
<input type="submit" value=" 提 交 " name="Bl"> 
<input type="reset" value=" 重 置 " name="B2"> 
</form> 
</body> 
</html> 


file.html 文件 打开 后 ， 单 击 “ 选 择 文件 ”按钮 ， 选 择 好 文件 ， 最 后 再 单 击 “ 提 交 ” 按 
钮 ， 如 图 7-12 所 示 。 


.faN. 


om 多 Dam 站 


国 1ccalhest/sile ht=1 x 
€ © | BD localhost/file. htnl 


[六 镍 | 个 人 簿 介 doc 


提交 | | 重 置 





7-12 file.html 文件 的 显示 结果 


创建 show_filephp， 用 于 接收 file.html 中 文件 上 传 控件 的 数据 ， 程 序 代 码 如 下 : 


<?php 
header ("Content-Type:text/html;charset=gb2312"); 
echo "你 选择 的 文件 是 : <br/>"; 
echo $_POST["my_file"]; 

> 


file.html 文件 数据 提交 后 的 运行 结果 如 图 7-13 所 示 。 


国 1ocalhost/shor file php x Wa 
~ @ 日 localhost/show file.php YY 


你 选择 的 文件 是 ， 


个 人 简介 . doc 





图 7-13 ”实例 7-7 数据 提交 后 的 运行 结果 


[ 提示 : 。 每 个 文件 上 传 框 只 能 选择 一 个 文件 。 
@ 使 用 文件 上 传 框 上 传 文件 时 ， 表 单 标签 <form> 的 enctype 属性 值 必须 设 
置 为 multipart/form-data，method 属性 必须 设置 为 POST 提交 方式 ， 即 


<form method="POST" enctype="multipart/form-data" action="">。 


PHP 程序 上 传 文件 的 代码 将 在 第 12 章 中 详细 列 出 。 
7.2 ”综合 实 训 案例 


本 节 主 要 介绍 用 户 注册 页 面 的 设计 方法 和 步骤 。 
1. 分 析 


创建 静态 网 页 文件 register html， 包 含 一 个 form 表单 ， 添 加 用 于 注册 信息 的 控件 ， 控 
件 的 属性 如 表 7-15 所 示 。 
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表 7-15 注册 信息 控件 的 属性 























控件 类 型 属 性 说 明 

文 本 框 name=user name type=text 用 户 名 称 
文本 框 name=passwordl] type=password 登录 密码 
文本 框 name=password2 type=password 确认 密码 
单 选 按钮 Name=sex type=radio 性 别 

复 选 框 Name=interests| =checkbox 个 人 爱好 
文本 域 Name=remark 备注 

register.html 页 面 打 开 后 ， 用 户 依次 输入 注册 信息 ， 最 后 单 击 “ 提 交 ” 按 钮 即 可 ， 如 














图 7-14 所 示 。 


所 localhost/register. html 


用 户 名 ， 
登录 密码 ， 
确认 窗 码 ， 
性 别 ， 
爱好 

这 是 我 的 个 人 信息 * 


备注 ， 





图 7-14 用 户 注册 信息 


创建 PHP 程序 文件 upload_registerphp， 用 来 接收 registerhtml 页 面 传递 过 来 的 数据 。 
程序 运行 结果 如 图 7-15 所 示 。 


日 1 
确认 密码 ，abc123 
性 别 , 男 


爱好 ,音乐 体育 旅游 
备注 ， 这 是 我 的 个 人 信息 。 





图 7-15 PHP 程序 接收 的 提交 数据 


2. 程序 代码 
register.html 程序 代码 如 下 : 


<html> 
<head> 
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<meta http-equiv="Content-Language" content="zh-cn"> 

<meta http-equiv="Content-Type" content="text/html; charset=gb2312"> 

<title> 用 户 注册 </title> 

</head> 

<body> 

<form action ="upload register.php" method =post > 

<p align="center"> 用 户 注册 <br/> 

用 户 名 : <input type="text" name="user_name" size="20"><br/> 

登录 密码 : <input type="password" name="passwordl" size="20"><br/> 

确认 密码 : <input type="password" name="password2" size="20"><br/> 

性 别 : <input type="radio" value=" 男 " name="sex"> 男 gnbsp; gnbsp; 
<input type="radio" value=" 女 " name="sex" > 女 <br/> 

爱好 : <input type="checkbox" name="interests[]" value=" 音 乐 "> 音乐 enbsp; 
<input type="checkbox" name="interests[]" value=" 美 术 "> 美 术 gnbsp; 
<input type="checkbox" name="interests[]"” value=" 体 育 "> 体 育 &nbsp; 
<input type="checkbox" name="interests[]"” value=" 旅 游 "> 旅游 <br/> 

备注 : <textarea rows="6" name="remark" cols="74"></textarea><br/> 

<p align="center"><input type="submit" value=" 提 交 " 

name="Bl">&nbsp; tnbsp; tnbsp; tnbsp; tnbsp; 

<input type="reset" value=" 重 置 " name="B2"><br/> 

</form> 

</body> 

</html> 


upload_register.php 程序 代码 如 下 : 


<?php 
header ("Content-Type:text/html;charset=gb2312"); 
echo "用 户 名 : ",$_POST["user_name"], "<br/>"; 
echo "密码 : ", $_POST["password1"], "<br/>"; 
echo "确认 密码 : ",$_POST["password2"], "<br/>"; 
if(isset($ POST["sex"])){ 
echo "性 别 : ",$_POST["sex"],"<br/>"; 
} 
elsel 
echo "性 别 : 未 选择 ! ", "<br/>"; 
} 
eeho "爱好 
foreach($_POST["interests"] as $interest){ 
echo $interest," "7 
} 
echo "<br/>"; 
echo "备注 : ",$_POST["remark"], "<br/>"; 


本 章 小 结 


本 章 主要 介绍 了 HTML 表单 、 表 单 控件 的 属性 及 应 用 方法 ， 以 及 在 PHP 中 获取 表单 
控件 数据 的 方法 。 


/TN. 
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1. 编写 程序 ， 接 收 如 图 7-16 所 示 页 面 传递 的 文本 框 信息 。 


邮箱 ，jiianjun_i@163.com 
| 提交 重 轩 





图 7-16 文本 框 信息 
2. 编写 程序 ， 接 收 如 图 7-17 所 示 页 面 传递 的 单 选 按钮 信息 。 


EE] 







窑 | 主 
副教授 目 讲 师 全 助教 
| [| 
图 7-17 单 选 按 钮 信息 
3. 编写 程序 ， 接 收 如 图 7-18 所 示 页 面 传递 的 复 选 框 信息 。 


园 % = 
a 


CC DD localhost/abc. htm 
信息 来 源 ， 目 电视 目 报纸 目 网 络 目 杂 志 目 聊 天 
| 提交 | | 重要 | 
图 7-18 复 选 框 信息 
4. 编写 程序 ， 接 收 如 图 7-19 所 示 页 面 传递 的 下 拉 列 表 框 信息 。 


Sl 


7-19 下 拉 列 表 框 信息 
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本 章 要 点 


@ 。 MySQL 数据 库 的 操作 (创建 、 选 择 和 删除 ) 

@ MySQL 数据 表 的 操作 (创建 、 查 看 、 修 改 、 重 命名 和 删除 ) 
@ MySQL 数据 的 操作 (添加 、 修 改 、 删 除 和 查询 ) 

学 习 目标 

@ 掌握 MySQL 数据 库 操 作 的 相关 命令 

@ 掌握 MySQL 数据 表 操 作 的 相关 命令 

@ 掌握 MySQL 数据 操作 的 相关 命令 


8.1 MySQL 的 启动 和 关闭 


8.1.1 MySQL 服务 器 的 启动 


启动 XAMPP 控制 面板 ， 单 击 MySQL 右 侧 对 应 的 Start 按钮 ， 即 可 启动 MySQL 服务 
器 ， 如 图 8-1 所 示 。 






rE] 





ser | sam | conm | tao | ou 





XAMPP Control Panel v3.2.2 om | 
Sevice Module Po Port(s) Actions _ Snestet | 
x| Apache 5 80,443 Stop Admn Confg Logs _ 国 shel | 上 | 
区 | wso -em 3306 Admn | confg | Los _ Explorer 
加 Mercury ster | am |_conto | toos Hep 
其 | 。 Tomcat 








[nain] 
[nain] 
[main] 
5 [mysql] 


Initializing Modules 
Starting Check-Tiner 
Control Panel Ready 
Attempting to start MySQL app... 


本 












6 [mysql] 
6 [Apache] 
6 [Apache] 


Status change detected: runming 
Attempting to start Apache app. 
Status change detected: rurming 








图 8-1 启动 MySQL 服务 器 
8.1.2 连接 MySQL 服务 器 


MySQL 服务 器 启动 后 ， 就 可 以 连接 MySQL 服务 器 了 。 可 以 在 PHP 程序 中 通过 程序 
命令 来 连接 MySQL 服务 器 ， 也 可 以 使 用 命令 行 来 实现 。 在 这 里 主要 介绍 使 用 命令 行 来 连 
接 MySQL 服务 器 。 


命令 行 连接 MySQL 服务 器 的 命令 格式 如 下 : 


mysql -u user -h host -p password 
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此 命令 中 的 三 个 参数 应 户 提供 。 

@ user: 登录 MySQL 服务 器 的 用 户 名 。 

@ host: MySQL 服务 器 的 地 址 。 

@ password: 登录 MySQL 服务 器 的 密码 。 

在 XAMPP 控制 面板 上 单 击 右 侧 的 图 标 Shell， 在 弹出 的 窗口 内 输入 命令 : 


mysql -u root -h localhost 


即 可 成 功 连接 MySQL 服务 器 ， 如 图 8-2 所 示 。 





























\h’ for help. Type ’\c’ to clear the current input statement. 








图 8-2 命令 行 连接 MySQL 服务 器 
[对 提示 : XAMPP 系统 集成 的 MySQL 服务 器 默认 没有 设置 登录 密码 ， 因 而 命令 行 连 
接 MySQL 服务 器 时 无 须 使 用 -p 参数 。 为 了 安全 起 见 ， 建 议 用 户 自行 设置 
MySQL 服务 器 的 登录 密码 。 
8.1.3 关闭 MySQL 服务 器 


在 XAMPP 控制 面板 上 ， 单 击 MySQL 右 侧 对 应 的 按钮 Stop， 即 可 关闭 MySQL 服 
务 器 。 


8.2 字 符 集 


8.2.1 ”字符 集 简介 











字符 (CharacteD) 是 各 种 文字 和 符号 的 总 称 ， 包 括 各 个 国家 的 文字 、 标 点 符号 、 图 形 符 
号 、 数 字 等 。 字 符 集 (Character Seb 是 多 个 字符 的 集合 ， 字 符 集 种 类 较 多 ， 每 个 字符 集 包 含 
的 字符 个 数 不 同 ， 常 见 字符 集 名 称 : ASCII 字符 集 、GB2312 字符 集 、UTF-8 字符 集 、 
Unicode 字符 集 等 。 计 算 机 要 准确 地 处 理 各 种 字符 集 文字 ， 需 要 进行 字符 编码 ， 以 便 计算 
机 能 够 识别 和 存储 各 种 文字 。 











8.2.2 MySQL 字符 集 





MySQL 字符 集 常见 的 有 ASCII 字符 集 、GB2312/GBK 字符 集 、Unicode 字符 集 
UTF-8 字符 集 等 。 


的 


mm PHP 动态 网 页 设计 教程 


1. ASCIl 字符 集 


ASCII(American Standard Code for Information Interchange, 美 国标 准 信息 交换 代码 表 ) 是 
由 美国 国家 标准 学 会 (American National Standard Institute, ANSI ) 制 定 的 标准 的 单字 节 字 符 
编码 方案 ， 用 于 基于 文本 的 数据 。ASCII 是 基于 拉丁 字母 的 一 套 电 脑 编码 系统 ， 它 主要 用 
于 显示 现代 英语 和 其 他 西欧 语言 ， 是 现今 通用 的 单字 节 编 码 系统 。 

ASCII 码 使 用 指定 的 7 位 或 8 位 二 进 制 数组 合 来 表示 128 或 256 种 可 能 的 字符 。 标 
准 ASCII 码 也 叫 基础 ASCII 码 ， 使 用 7 位 二 进 制 数 来 表示 所 有 的 大 小 写字 母 ， 数 字 0 一 
9、 标 点 符号 ， 以 及 在 美式 英语 中 使 用 的 特殊 控制 字符 。 

2，GB 2312/GBK 字符 集 


GB 2312 是 中 华人 民 共 和 国 国家 汉字 信息 交换 用 编码 ， 全 称 《信息 交 换 用 汉字 编码 字 
符 集 等 基本 集 》(GB 2312 一 1980)，1980 年 由 国家 标准 总 局 发 布 。 基 本 集 共 收入 汉字 6763 
个 和 非 汉 字 图 形 字符 682 个 ， 通 行 于 中 国 大 陆 ， 新 加 坡 等 地 也 使 用 此 编码 。GBK 是 对 
GB 2312 的 扩展 ， 它 包含 2 万 多 个 字符 ， 除 了 保持 与 GB 2312 的 兼容 外 ， 还 扩充 了 部 分 
Unicode 中 没有 的 字符 。 

3. Unicode 字符 集 


Unicode 字符 集 (Universal Multiple-Octet Coded Character)， 是 一 个 名 为 Unicode 学 术 学 
会 (Unicode Consortium) 机 构 制 定 的 字符 编码 系统 ， 支 持 目前 各 种 不 同 语言 的 处 理 及 显示 。 
Unicode 为 每 种 语言 中 的 字符 设 定 了 统一 而 且 唯一 的 二 进 制 编码 ， 满 足 了 跨 语 言 、 跨 平台 
进行 文本 转换 和 处 理 的 需求 。 

4. UTF-8 编码 


UTF-8(8-bit Unicode Translation Format) 是 一 种 针对 Unicode 的 可 变 长 度 字符 编码 ， 又 
称 万 国 码 ， 是 Unicode 的 一 种 使 用 方式 。UTF-8 用 1 一 4 个 字 节 编码 Unicode 字符 。 在 网 页 
上 可 以 在 同一 页 面 中 显示 中 文 简体 、 繁 体 及 其 他 语言 (如 日 文 、 韩 文 )。 

UTF-8 以 字 节 为 单位 对 Unicode 进行 编码 。 从 Unicode 到 UTF-8 的 编码 方式 ， 如 表 8-1 
所 示 。 






























































表 8-1 Unicode 和 UTF-8 编码 方式 


Unicode 编码 (十 六 进 制 ) 
000000 - 00007F 
000080 - 0007FF 
000800 - O0FFFF 
010000 - 10FFFF 


UTF-8 字 节 流 (二 进 制 ) 





110xxxxx 10xxxxxx 
lllOxxxx 10xxxxxx 10xxxxxx 
11110xxx 10xxxxxx 10xxxxxx 10XXXXXX 


UTF-8 的 特点 是 针对 不 同 范围 的 字符 使 用 不 同 长 度 的 编码 。 对 于 0x00 一 0x7F 之 间 的 
字符 ，UTF-8 编码 与 ASCII 编码 完全 相同 。UTF-8 编码 的 最 大 长 度 是 4B。 从 上 表 可 以 看 
出 ，4B 模板 有 21 个 x， 即 可 以 容纳 21 位 二 进 制 数 字 。 

MySQL 字符 集中 各 项 系统 变量 说 明 如 下 。 
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character_set_server: MYSQL 服务 器 的 字符 集 。 

character_set_client: 客户 端 来 源 数据 使 用 的 字符 集 。 
character_set_connection: 连接 层 字 符 集 。 

character_set_database: 当前 选中 数据 库 的 字符 集 。 
character_set_results: 操作 结果 集 的 默认 字符 集 。 
character_set_system: 元 数据 (字段 名 、 表 名 、 数 据 库 名 等 ) 字 符 集 。 


8.2.3 MySQL 中 的 字符 集 转 换 过 程 


MySQL 服务 器 在 运行 过 程 中 ， 客 户 端 和 服务 器 端 要 进行 字符 集 的 转换 。MySQL 中 字 
符 集 的 转换 过 程 如 图 8-3 所 示 。 





character_set_connection 


MySQL 服务 器 






eo haracter set_server 
a | ee 
ee es i | sosoos 


character set_results 


| 





返回 结 : 











8-3 MySQL 服务 器 字符 集 转换 过 程 

说 明 3 

@ 进入 XAMPP Shell 窗口 ， 连 接 MySQL， 此 时 客户 端的 字符 集 为 
character_set_client 定义 的 字符 集 。 

@ ”在 XAMPP Shell 窗口 内 输入 MySQL 命令 或 SQL 语句 ， 则 向 MySQL 服务 器 发 送 
请 求 数据 ， 此 时 需要 将 客户 端的 请 求 数据 从 character_set_client 字符 集 转换 为 服 
务 器 连接 的 character_set_connection 字符 集 。 

@ MySQL 服务 器 收 到 MySQL 客户 端 发 来 的 请 求 数据 后 ， 需 要 将 这 些 请 求 数据 从 服 
务 区 连接 的 character set_connection 字符 集 转换 到 MySQL 服务 器 的 
character_set_server 字符 集 。 


[ 导 提示 : ”车 没有 设置 MySQL 服务 器 的 character_set_server 字符 集 ， 则 使 用 对 应 数据 
库 设 定 的 字符 集 。 
@” 若 MySQL 命令 或 SQL 语句 是 针对 数据 库 进行 操作 的 ， 则 需要 将 请 求 数据 从 


MySQL 服务 器 的 character set server 字符 集 转 换 到 该 数据 库 的 
character_set_database 字符 集 。 





(a. 


a 


怪 提示 : ”车 没有 设 定 该 数据 库 的 character_set_database 字符 集 ， 则 使 用 对 应 数据 表 设 
@ 当 MySQL 命令 或 SQL 语句 执行 完毕 ， 将 执行 结果 由 数据 库 的 character_set_ 
database 字符 集 转换 到 MySQL 服务 器 的 character_set_server 字符 集 。 
@ ”将 执行 结果 沿 着 已 打开 的 MySQL 连接 ， 从 MySQL 服务 器 的 character_set_server 
字符 集 转 换 到 character_set_results 字符 集 。 
@ ”将 操作 结果 从 character_set_results 字符 集 转换 到 character_set_client 字符 集 ， 将 结 
果 显示 到 客户 端 。 


8.2.4 MySQL 字符 集 的 设置 


在 某 些 情况 下 ， 由 于 客户 端 、 连 接 层 、 服 务 器 端 和 结果 集 的 字符 集 不 一 致 ， 导 致使 用 
中 文 查询 时 会 出 现 乱 码 现象 。 为 了 避免 出 现 乱码 或 为 了 方便 中 文 查询 ， 需 要 对 MySQL 的 
字符 集 进行 相应 的 设置 ， 常 用 的 方法 有 以 下 三 种 。 

(1) 设置 php.ini 文件 。 

打开 php.ini 文件 ， 将 default_charset 选项 设置 为 要 选用 的 字符 集 ， 如 图 8-4 所 示 。 





剧 php_ini - 记事 本 Te 
文件 中) 编辑 下 ) 格式 10) 查看 W) 帮助 00 

习 
; PHP's default character set is set to UTF-8. 昌 


; http://php.net/default-charset 
default_charset="UTF-8" 





8-4 在 php.ini 文 件 中 设置 MySQL 默认 字符 集 
(2) 用 mysqli_query0 函 数 设置 字符 集 。 
mysqli_query() 函 数 的 语法 格式 为 
mysqli_query (resource conn, string str) 
参数 说 明 如 表 8-2 所 示 。 
表 8-2 mysqli_query() 参 数 说 明 


参 数 含义 
conn MySQL 服务 器 连接 标识 符 





字符 集 设置 命令 格式 为 set names charset。 如 要 设置 为 简体 中 文字 符 集 ， 可 以 写 为 set 
names gb2312 


str 





函数 功能 : 一 次 性 设置 character_client、character_set_connection 和 character_set_results 
字符 集 。 其 中 set names x 语句 等 价 于 以 下 三 条 语句 : 


set character set client = x; 
set character set connection = x; 
set character set results = x; 
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(3) 使 用 MySQL 命令 设置 字符 集 。 
打开 XAMPP Shell 窗口 ， 输 入 MySQL 命令 设置 字符 集 。 例 如 : 


Set character set client=gb2312; 

Set character set connection=gb2312; 
Set character set database=gb2312; 
Set character set_sever=gb2312; 

Set character set_ results=gb2312; 


设置 完 后 ， 可 以 使 用 MySQL 命令 “show variables like 'character%';” 查 看 MySQL 当 
前 的 字符 集 。 


8.3 操作 数据 库 


F 面 介绍 关于 MySQL 数据 库 的 相关 操作 ， 包 括 : 数据 库 的 查看 、 创 建 、 选 择 和 删除 
等 操作 。 


8.3.1 查看 数据 库 


利用 SHOW 显示 已 有 的 数据 库 ， 其 语法 格式 如 下 : 

SHOW DATABASES [LIKE wild] 

如 果 使 用 LIKE wild 部 分 ，wild 字符 串 可 以 是 一 个 使 用 SQL 的 “%” 和 “_” 通 配 符 
的 字符 串 。 

功能 : SHOW DATABASES 列 出 在 MySQL 服务 器 上 的 数据 库 。 

【实例 8-1】 显 示 当前 MySQL 服务 器 上 的 数据 库 信息 。 

进入 XAMPP Shell 窗口 ， 连 接 完 MySQL 服务 器 后 ， 输 入 命令 : 

show databases; 


显示 结果 如 图 8-5 所 示 。 














图 8-5 使 用 show databases 命令 查看 数据 库 信 息 


【实例 8-2】 显 示 以 “t” 开 头 命名 的 数据 库 信息 。 





进入 XAMPP Shell 窗口 ， 输 入 命令 : 
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Show databases like "ts'7 


查询 结果 如 图 8-6 所 示 。 














8-6 查看 以 “t” 开 头 命名 的 查看 数据 库 信息 


8.3.2 创建 数据 库 


利用 CREATE DABASE 创建 数据 库 ， 其 语法 格式 如 下 : 
CREATE DATABASE db_name 
功能 : 创建 以 db_name 命名 的 数据 库 。 

【实例 8-3】 创 建 一 个 名 为 bookmanage 的 数据 库 。 


Create Database bookmanage; 


[六 提示 :  。 如 果 数 据 库 已 经 存在 、 数 据 库 的 名 称 非法 或 者 对 创建 的 数据 库 文 件 天 没 

有 足够 的 权限 都 会 在 创建 数据 库 时 导致 错误 。 
e@ MySQL 中 的 每 一 个 数据 库 都 对 应 于 系统 的 一 个 文件 夹 。 数 据 库 在 刚 创建 
时 没有 包含 任何 数据 表 ， 因 此 可 以 理解 为 CREATE DATABASE 语句 只 
是 在 MySQL 的 数据 库 文件 夹 下 创建 了 一 个 以 数据 库 名 称 命名 的 新 文件 
夹 。 据 此 原理 ， 按 照 以 下 步骤 也 可 以 创建 数据 库 。 
GD 进入 cixampp\mysql\data 文件 夹 下 ， 创 建文 件 夹 my_database。 
@ 进入 XAMPP Shell 窗口 ， 输 入 命令 
Show databases like "my 当 '7 


查看 数据 库 的 信息 ， 查 询 结果 如 图 8-7 所 示 。 














图 8-7 数据库 查询 信息 


.faN， 


第 8 章 MySQL 数 扣 订 全 
8.3.3 选择 数据 库 
USE 语句 用 于 选择 一 个 数据 库 ， 并 使 其 成 为 当前 默认 数据 库 ， 其 语法 格式 如 下 : 


USE db name 
































8.3.4 删除 数据 库 
使 用 DROP DATABASE 语句 可 以 删除 数据 库 ， 其 语法 格式 如 下 : 


DROP DATABASE [IF EXISTS] db name 


功能 : DROP DATABASE 删除 数据 库 中 的 所 有 表 和 数据 库 。 关 键 词 下 EXISTS 是 检 
测 数据 库 是 否 存在 。 

【实例 8-4】 创 建 一 个 名 为 reader 的 数据 库 ， 并 查看 该 数据 库 ， 最 后 删除 该 数据 库 。 

Create Database reader; 


Show databases like 'r%'; 
drop database reader; 





8.4 操作 数据 表 
数据 库 创建 完成 后 ， 就 可 以 在 该 数据 库 下 进行 数据 表 的 操作 了 。 数 据 表 的 操作 包括 : 
创建 数据 表 、 修 改 数 据 表 和 删除 数据 表 。 
8.4.1 创建 数据 表 
使 用 CREATE TABLE 语句 可 以 创建 数据 表 ， 其 语法 格式 如 下 : 


CREATE [TEMPORARY] TABLE [IF NOT EXISTS] tbl name[ (create definition,...)] 
[table_options] [select_statement] 


CREATE TABLE 语句 的 参数 说 明 如 表 8-3 所 示 。 
表 8-3 CREATE TABLE 语句 参数 说 明 











参 数 说 明 
该 关键 字 表示 创建 一 个 临时 表 。 如 果 与 当前 MySQL 的 连接 关闭 ， 则 临时 表 会 被 
TEMPORARY 
MySQL 自动 删除 
正 NOTEXISTS | 该 关键 字 用 于 避免 数据 表 已 存在 时 MySQL 报告 的 错误 
tbl_name 要 创建 的 数据 表 的 名 称 





这 是 数据 表 的 列 属性 的 第 一 部 分 。MySQL 要 求 创建 数据 表 时 ， 至 少 包含 一 列 ， 
详细 内 容 见 表 8-5 

表 的 一 些 特 性 参数 

SELECT 语句 描述 部 分 


create_ definition 





table_options 








select_statement 
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create_definition 格式 如 下 : 


col name type [NOT 


NULL |NULL] [DEFAULT 


default vale] [AUTO_INCREMENT] [PRIMARY KEY] [reference definition] 


create_definition 的 参数 说 明 如 表 8-4 所 示 。 


表 8-4 create definition 参数 说 明 














参 数 说 明 
col_ name 字段 名 
type 字段 类 型 
NOT NULL | NULL 指出 该 列 是 否 为 空 值 ， 系 统一 般 默认 为 生 








DEFAULT default_value 


AUTO_INCREMENT 





默认 值 
表示 是 否 为 自动 编号 。 每 个 表 只 能 有 一 个 AUTO_INCREMENT 列 ， 而 且 
必须 被 索引 





PRIMARY KEY 


reference_definition 





是 否 为 主键 。 一 个 表 只 能 有 一 个 主键 
字段 的 注释 


【实例 8-5】 在 bookmanage 数据 库 中 创建 数据 表 book， 该 表 的 字段 信息 如 表 8-5 所 示 。 


表 8-5 表 book 的 字段 信息 











字 段 类 型 (长 度 ) 含义 
bookid VARCHAR(8 图 书 编号 
bookname VARCHAR(60. 图 书 名 称 
editor VARCHAR(8 作者 
price FLOAT(5.0 价格 

_publish VARCHAR(G0) 出 版 社 
pubdate DATE 出 版 日 期 
kcl INT(4 库存 量 

进入 XAMPP Shell 窗口 ， 依 次 输入 以 下 命令 : 


use bookmanage; 


// 打 开 数 据 库 bookmanage 


create table book // 创 建 数 据 表 book 


( 
bookid varchar (8) 


a 


bookname varchar (60), 


editor varchar (8) 
price float(5,0), 


a 


publish varchar (30), 


pubdate date, 
kcl int(4) 


)default charset=utf8; / /数据 表 的 字符 集 为 utf-8 








运行 结果 如 图 8-8 所 示 。 
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图 8-8 创建 数据 表 book 
8.4.2 显示 数据 表 的 信息 


利用 SHOW/ DESCRIBE 语句 显示 数据 表 的 信息 。 

(1) 显示 数据 表 的 信息 。 

SHOW TABLES [FROM db name] [LIKE wild] 

功能 : 列 出 一 个 给 定 的 数据 库 中 的 所 有 数据 表 。 

【实例 8-6】 显 示 bookmanage 数据 库 中 的 所 有 数据 表 。 


use bookmanage; 
Show tables ; 


或 者 
show tables from bookmanage; 


查询 结果 如 图 8-9 所 示 。 


可 管理 员 : XANPP for 














图 8-9 实例 8-6 运行 结果 图 


(2) 显示 数据 表 中 字段 的 信息 。 
语法 格式 : 
SHOW COLUMNS FROM tb] name [FROM db name] [LIKE wild] 


功能 : 列 出 一 个 给 定数 据 表 中 的 所 有 字段 及 其 类 型 。 
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中 : tbl name FROM db_name 可 以 使 用 db_name.tbl_ name 来 代替 。 
【实例 8-7】 显 示 book 数据 表 中 的 所 有 字段 。 

show columns from book from bookmanage; 

或 

show columns from bookmanage.book; 


运行 结果 如 图 8-10 所 示 。 


EE 














图 8-10 实例 8-7 运行 结果 图 
8.4.3 ”修改 数据 表 


当 应 用 环境 和 应 用 需求 发 生变 化 时 ， 经 常 需要 修改 基本 表 的 结构 。 使 用 ALTER 
TABLE 语句 可 以 修改 数据 表 的 结构 。 

(1) 增加 列 。 

语法 格式 : 

alter table tbl_name add col name type 

例如 为 book 表 增 加 一 列 weight: 

alter table book add weight int; 

(2) 删除 列 。 

语法 格式 : 

alter table tbl_name drop col name 

例如 ， 删 除 列 weight: 

alter table book drop weight; 

(3) 修改 列 。 

语法 格式 : 

alter table tbl name modify col name type 


或 者 
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alter table tbl_name change old col name col_name type 
例如 ， 修 改 列 weight 的 类 型 : 
alter table book modify weight samllint; 
或 者 
alter table book change weight weight smallint; 


(4) 列 更 名 。 

语法 格式 : 

alter table old table name change old col name col name 
例如 ， 再 将 列 weight 改 为 21: 

alter table book change weight zl1; 


(5) 表 更 名 。 
语法 格式 : 


alter table old table name rename new_ table name 


例如 ， 把 book 表 更 名 为 ts: 


alter table book rename ts; 


8.4.4 删除 数据 表 
利用 DROP TABLE 语句 可 以 删除 数据 表 ， 语 法 格式 如 下 : 


DROP TABLE [IF EXISTS] tbl name [, tbl name,...] 


DROP TABLE 删除 一 个 或 多 个 数据 表 ， 表 中 的 所 有 数据 和 表 定 义 均 被 删除 。 
例如 ， 删 除 bookmanage 数据 库 中 的 表 book。 


use bookmanage; 
drop table book; 


或 者 
drop table bookmanage. book; 


8.5 操作 数据 


操作 数据 是 针对 数据 表 中 的 记录 进行 的 操作 ， 主 要 包括 : 新 增 记录 、 修 改 记录 和 删除 
记录 。 


8.5.1 ”新 增 记录 
使 用 INSERT 语句 可 以 向 数据 表 内 插入 新 数据 ， 语 法 格式 如 下 : 
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INSERT [INTO] tbl name [ (column namel,column name?2,...)] VALUES 
(valuel,value2,.。:) 
或 


INSERT [INTO] tbl name SET column namel=valuel, column name2=value2,... 


功能 : 在 指定 的 数据 表 的 尾部 插入 一 条 新 记录 ， 其 值 为 VALUES( 或 = ) 后 面 表达 式 
的 值 。 

说 明 : 当 需 要 插入 表 中 所 有 字段 的 数据 时 ， 表 名 后 面 的 字段 名 可 以 省 略 ， 但 插入 数据 
的 格式 及 顺序 必须 与 表 的 字段 次 序 完全 一 致 ， 若 只 需要 插入 表 中 某 些 字段 的 数据 ， 则 需要 
列 出 插入 数据 的 字段 名 。 

INSERT 语句 具有 几 种 形式 。 

(1) 指定 所 有 列 的 值 。 

【实例 8-8】 向 book 表 中 添加 记录 ，bookid 为 “000012”，bookname 为 “西方 经 济 
学 ”，editor 为 “ 刘 进 步 ”，Price 为 38，publish 为 “清华 大 学 出 版 社 ”，pubdate 为 
“2012-10-23”，kcl 为 20。 

insert into Book values ("000012", "西方 经 济 学 "," 刘 进步 ", 38, "清华 大 学 出 版 社 

02=1023" 20)3 

也 可 以 写成 : 


insert into reader setbookid="000012",bookname=" 西 方 经 济 学 ", editor=" 刘 进步 
",price=38,publish=" 清 华 大 学 出 版 社 "，pubdate="2012-10-23", kcl=20; 


缉 提示 : 向 表 中 添加 记录 时 ，VALUES 后 面 表达 式 的 顺序 必须 与 数据 表 的 字段 的 顺 
序 一 致 ， 并 且 类 型 要 匹配 。 
(2) 指定 部 分 列 的 值 。 
【实例 8-9】 向 book 表 中 添加 记录 ，bookid 为 “000013”，bookname 为 “线性 代 
数 ”，publish 为 “高 等 教育 出 版 社 ”。 


insert into Book (bookid,bookname,publish) values ("000013", "线性 代数 ", "高 
等 教育 出 版 社 ") ; 


[对 提示 : 只 指定 部 分 字段 的 值 时 ， 必 须 在 表 名 后 面 的 括号 内 列 出 字段 的 名 称 ， 
VALUES 后 面 表达 式 的 顺序 必须 与 前 面 列 出 的 字段 顺序 一 致 ， 并 且 类 型 要 
匹配 。 

(3) 一 次 插入 多 行 数 据 。 
使 用 INSERT 语句 可 以 一 次 插入 多 条 记录 ， 语 句 格式 如 下 : 
insert into book values 


("000014", "哲学 ", "王强 ",28, "清华 大 学 出 版 社 ", "2008-06-23",120)， 
("000015", "大 学 计算 机 基础 ", " 宋 天 文 ", 30, "经 济 出 版 社 ", "2011-07-18",200) 
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8.5.2 ”批量 增加 记录 
使 用 LOAD 语句 可 以 向 数据 表 批量 插入 数据 ， 语 法 格式 如 下 : 


LOAD DATA [LOCAL] INFILE 'file name.txt' [REPLACE | IGNORE] INTO TABLE 

tb1l1_name 

@ INFILE: 从 一 个 文本 文件 中 读 取 数 据 插 入 表 中 。 如 果 指 定 LOCAL 关键 词 ， 从 客 
户主 机 读 文件 ， 否 则 要 从 服务 器 上 读 取 文件 。 

@ REPLACE 和 IGNORE: 控制 对 现 有 的 唯一 键 记录 的 重复 的 处 理 。 如 果 指 定 了 
REPLACE， 新 行将 代替 具有 相同 唯一 键 值 的 现 有 行 。 如 果 指 定 了 IGNORE， 跳 
过 具有 唯一 键 的 现 有 行 的 重复 行 的 输入 。 如 果 没 有 指定 任何 一 个 选项 ， 当 找到 重 
复 键 时 ， 会 出 现 一 个 错误 ， 并 且 文 本 文件 的 余下 部 分 将 不 被 插入 表 中 。 

如 果 使 用 了 LOCAL 关键 词 从 本 地 文件 插入 数据 ， 服 务 器 无 法 在 操作 的 过 程 中 停止 文 

件 的 传输 ， 因 此 省 略 的 行为 好 像 IGNORE 被 指定 一 样 。 
【实例 8-10】 向 book 表 中 添加 多 条 记录 ， 记 录 已 经 保存 在 b.txt 文件 中 。 


LOAD DATA INFILE "“b.txt" INTO TABLE bookmanage.book; 








8.5.3 ”修改 记录 
使 用 UPDATE 命令 可 以 更 新 存储 在 数据 表 中 的 记录 ， 语 法 格式 如 下 : 


UPDATE table name 
SET column namel=valuel{[, column name2 =value2...] 


[WHERE < 条 件 表达 式 >] 


功能 : 更 改 符合 WHERE 条 件 的 记录 。 如 果 不 指定 条 件 ， 则 表 中 的 所 有 记录 均 被 
更 改 。 

【实例 8-11】 将 book 表 bookname 字段 的 值 为 “大 学 计算 机 基础 ”的 所 有 记录 的 
“price” 字 段 值 改 为 48。 


UPDATE book SET price=48 WHERE bookname =" 大 学 计算 机 基础 "; 


8.5.4 删除 记录 
使 用 DELETE 命令 可 以 删除 数据 表 中 的 记录 。 其 语法 格式 为 : 


DELETE FROM table name 
[ WHERE < 条 件 表达 式 >] 


功能 : 从 指定 数据 表 中 删除 记录 。 
【实例 8-12】 删除 book 表 中 字段 editor 的 值 为 “王建 军 ” 的 所 有 记录 。 


DELETE FROM book WHERE editor= "王建 军 "; 
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[对 提示 : ”使 用 DELETE 命令 删除 记录 时 ， 一 般 都 要 附带 子 命令 WHERE < 条 件 >， 否 


则 数据 表 中 的 所 有 记录 均 会 被 删除 而 无 法 恢复 。 


8.6 ”数据 查询 语句 


在 数据 表 中 查询 数据 可 以 使 用 SELECT 语句 。SELECT 语句 的 语法 格式 如 下 : 


SELECT [ALL | DISTINCT] < 目标 列表 达 式 > [，--，mnl 

FROM 数据 源 

[WHERE ”过 滤 条 件 

[GROUP BY 分 组 表达 式 ] 

[HAVING 分 组 过 滤 条 件 ] 

[ORDER BY 排序 表达 式 [ASCI|DESC]] 

@ SELECT 子 句 : 说 明 要 查询 的 数据 列 ，ALL 表示 不 去 掉 重 复元 组 ，DISTINCT 表 
示 去 掉 重复 元 组 ， 默 认为 ALL。 

@ FROM 子 句 : 说 明 查 询 结果 来 源 于 哪些 数据 表 ， 既 可 以 基于 单个 数据 表 ， 也 可 以 

基于 多 个 数据 表 进行 联合 查询 。 

WHERE 子 句 : 说 明 查 询 条 件 ， 即 元 组 选择 的 条 件 。 

GROUP BY 子 句 : 用 于 对 查询 结果 进行 分 组 ， 可 以 利用 它 进 行 分 组 汇总 。 

HAVING 子 句 : 用 于 限定 分 组 必须 满足 的 条 件 ， 必 须 与 GROUP BY 子 句 一 起 使 用 。 

ORDER BY 子 句 : 用 于 对 查询 结果 进行 排序 。 


8.6.1 单 表 查询 


单 表 查 询 是 指 基于 一 个 数据 表 的 数据 查询 。 
1. 选择 数据 表 中 若干 列 


(1) 查询 指定 列 的 信息 。 
如 果 用 户 只 想 查 询 表 中 的 一 部 分 列 的 信息 ， 就 可 以 在 子 句 的 < 目标 列表 达 式 > 中 指定 要 


查询 的 列 的 名 称 。 


【实例 8-13】 查询 book 表 中 的 bookid、booknmaed、editor 等 字段 的 信息 。 


SELECT bookid,bookname,editor FROM book; 


运行 结果 如 下 所 示 : 

=== 记 = 二 和 = 二 == 
| bookid | bookname | editor | 
+ 一 一 一 一 一 一 一 十 一 一 一 一 一 一 一 一 一 一 一 一 一 一 一 一 一 一 一 二 一 一 一 一 一 一 一 一 + 
1 000012 | 西方 经 济 学 1 刘 进 步 ”| 
1 000002 | VB 程序 设计 jl 艺 华 
1 000003 | 计算 机 审计 基础 1 张 浩 1 
1 000004 1 大 学 语文 1 谭 一 益 1 
1 000005 1 计算 机 网 络 基础 | 刘 峰 1 
1 000006 | 高 等 数学 (第 四 版 上 ) ”| 同济 大 学 | 
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1 000007 | 高 等 数学 (第 四 版 F) | 同济 大 学 | 
1 000008 | 大 学 英语 1 赵 乐 楚 | 
1 000009 | 计算 机 网 络 基础 1 谭 玉 龙 1 
1 000010 | 机 械 制图 1 张 龙 | 
| 000001 | matlab 与 绘图 1 张强 民 1 
十 一 一 一 一 一 一 一 一 十 一 一 一 一 一 一 一 一 一 一 一 一 一 一 一 一 一 一 十 一 一 一 一 一 一 一 一 + 


(2) 查询 全 部 列 的 信息 。 
【实例 8.14】 查询 book 表 中 所 有 字段 的 信息 。 


SELECT * FROM book; 


运行 结果 如 下 

+- 一 一 一 一 一 一 十 一 一 一 一 一 一 一 一 一 一 一 一 一 一 一 一 一 一 - 十 一 一 一 一 一 一 一 一 一 + 一 一 一 一 一 十 一 一 一 一 一 一 一 一 一 一 一 一 十 一 一 一 一 一 一 一 一 一 一 十 一 一 一 一 一 十 

| bookid | bookname | editor 1pricel publish | pubdate | kcl 

| 

十 一 一 一 一 一 一 一 十 一 一 一 一 一 一 一 一 一 一 一 一 一 一 一 一 一 一 - 十 一 一 一 一 一 一 一 一 一 二 一 一 一 一 一 十 一 一 一 一 一 一 一 一 一 一 一 一 十 一 一 一 一 一 一 一 一 一 一 十 一 一 一 一 一 十 
000012 | 西方 经 济 学 1 刘 进 步 ”| 38 | 清华 大 学 出 版 社 1 2012-10-23| 20 | 
000002 | VB 程序 设计 1 刘 艺 华 1 28 | 高 等 教育 出 版 社 1 2009-08-02| 4 1 


Ke 
| | 
| | 
| 000003 | 计算 机 审计 基础 1 张 浩 1 45 | 机 械 工 业 出 版 社 | 2010-04-021 18 | 
| 000004 | 大 学 语文 1 谭 一 阔 ”| 23 | 水 电 出 版 社 1 2011-10-12| 32 1 
| 000005 | 计算 机 网 络 基础 | 刘 峰 1 30 1 北京 邮电 出 版 社 1 2012-08-12| 19 | 
1 000006 | 高 等 数学 (第 四 版 上 ) | 同济 大 学 | 33 | 高 等 教育 出 版 社 1 2000-01-08| 79 | 
1 000007 | 高 等 数学 (第 四 版 下 ) | 同济 大 学 | 30 | 高 等 教育 出 版 社 1 2000-01-08| 49 | 
1 000008 | 大 学 英语 | 赵 乐 楚 ” | 34 | 北京 外 国语 出 版 社 | 2014-06-181 17 | 
1 000009 | 计算 机 网 络 基础 1 谭 玉 龙 1 48 | 水 利水 电 出 版 社 1 2013-03-12| 39 | 
1 000010 1 机 械 制 图 1 张 飞 龙 1 35 | 机 械 工 业 出 版 社 | 2012-04-10| 21 | 
| 000001 | matlab 与 绘图 | 张强 民 1 38 1| 清华 大 学 出 版 社 1 2011-12-10| 10 | 
十 


(3) 为 列 命名 别名 。 

SELECT 子 句 可 以 为 < 目标 列表 达 式 > 中 的 列 命名 别名 。 

【实例 8-15】 从 book 表 中 查询 Bookid、Bookname、Editor 以 及 Pubdate 等 字段 的 
息 。 


SELECT Bookid as 图 书 编号 ,Bookname as 图 书 名 称 ,Editor as 主编 ，year (Pubdate) 
as 出 版 年 份 FROM Book; 


运行 结果 如 下 

计生 宝 3 a | 0 
1 图 书 编号 ”| 图 书 名 称 1 主编 。 | 出 版 年 份 | 
三 es ee 0 . 
| 000012 ”| 西方 经 济 学 1 刘 进 步 ”| 2012 | 
1 000002 | VB 程序 设计 | 刘 艺 华 | 2009 1 
1 000003 ”| 计算 机 审计 基础 | 张 浩 O20 
1 000004 ”| 大 学 语文 下 还 一同 ULE2000GI 
1 000005 ”| 计算 机 网 络 基础 1 刘 峰 W2020 
1 000006 ”| 高 等 数学 (第 四 版 上 ) | 同济 大 学 | 2000 | 
1 000007 ”| 高 等 数学 (第 四 版 下 ) | 同济 大 学 | 2000 | 
1 000008 ”| 大 学 英语 1 赵 乐 楚 1 2014 | 
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1 000009 ”| 计算 机 网 络 基础 | 谭 玉 龙 1 50 而 
1 000010 | 机 械 制 图 中 张 飞龙 中 20129| 
| 000001 ”| matlab 与 绘图 1 张强 民 1 ote | 
十 一 一 一 一 一 一 一 一 一 一 十 一 一 一 一 一 一 一 一 一 一 一 一 一 一 一 一 一 一 十 一 一 一 一 一 一 一 一 十 一 一 一 一 一 一 一 一 十 


2. 选择 表 中 若干 元 组 

(1) 过 滤 重 复 记 录 。 

在 查询 记录 时 ， 想 要 过 滤 某 字段 值 重 复 的 记录 ， 可 以 使 用 DISTINCT 关键 字 来 实现 。 
【实例 8-16】 查 询 book 表 中 出 版 社 的 名 称 (publish 字段 )。 

SELECT DISTINCT publish FROM book; 


运行 结果 如 下 : 




















1 清华 大 学 出 版 社 1 
1 高 等 教育 出 版 社 1 
1 机 械 工业 出 版 社 1 
1 水 电 出 版 社 | 
1 北京 邮电 出 版 社 1 
1 北京 外 国语 出 版 社 | 
1 水 利水 电 出 版 社 1 


(2) 查询 满足 条 件 的 记录 。 

查询 满足 指定 条 件 的 元 组 可 以 通过 WHERE 子 句 来 实现 。WHERE 子 句 常用 的 查询 条 
件 如 表 8-6 所 示 。 
表 8-6 常用 的 查询 条 件 














查询 条 件 谓词 
比较 = Se, MOT 
确定 范围 BETWEEN AND、 NOT BETWEEN AND 
确定 集合 IN、NOTIN 
字符 匹配 LIKE、NOT LIKE 
空格 ISNULL、ISNOTNULL 
逻辑 查询 AND、OR、1NOT 


【实例 8-17】 在 book 表 中 查询 出 版 社 为 “清华 大 学 出 版 社 ” 的 所 有 信息 。 


SELECT * FROM book WHERE publish=' 清 华 大 学 出 版 社 '; 


运行 结果 如 下 

+ 一 一 一 一 一 一 一 一 二 一 一 一 一 一 一 一 一 一 一 一 一 一 二 -一 一 一 一 一 一 + 一 一 一 一 一 二 一 一 一 一 一 一 一 一 一 一 一 一 一 二 一 一 一 一 一 一 一 一 一 一 一 + 一 一 一 一 一 + 
| bookid | bookname | editor1pricel publish | pubdate | kcl | 
+ 一 一 一 一 一 一 一 一 十 一 一 一 一 一 一 一 一 一 一 一 一 一 十 一 一 一 一 一 一 一 + 一 一 一 一 一 二 一 一 一 一 一 一 一 一 一 一 一 一 一 二 一 一 一 一 一 一 一 一 一 一 一 + 一 一 一 一 一 一 + 
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1 000012 | 西方 经 济 学 1 刘 进 步 | 381 清华 大 学 出 版 社 |2012-10-23 | 20 | 
1 000001 | matlab 与 绘图 | 张强 民 | ”381 清华 大 学 出 版 社 |2011-12-10 | 10 | 
二 一 一 一 一 一 一 一 一 和 赴 一 一 一 一 一 一 一 一 一 一 一 一 一 志 一 一 一 一 一 一 一 二 一 一 一 一 一 二 一 一 一 一 一 一 一 一 一 一 一 一 一 所 一 一 一 一 一 一 一 一 一 一 一 二 一 一 一 一 一 一 


【实例 8-18】 在 book 表 中 查询 出 版 社 为 “清华 大 学 出 版 社 ”、 库 存量 大 于 10 的 所 
有 信息 。 


SELECT * FROM book WHERE publish=' 清 华 大 学 出 版 社 ' AND kcl>10; 


运行 结果 如 下 

+ 一 一 一 一 一 一 一 一 二 一 一 一 一 一 一 一 一 一 一 一 一 + 一 一 一 一 一 一 + 一 一 一 一 一 一 十 一 一 一 一 一 一 一 一 一 一 一 一 一 一 十 一 一 一 一 一 一 一 一 一 一 + 一 一 一 一 一 一 十 
| bookid | bookname | editor | price | publish | pubdate ie 
+ 一 一 一 一 一 一 一 二 一 一 一 一 一 一 一 一 一 一 一 一 + 一 一 一 一 一 一 一 一 + 一 一 一 一 一 一 一 二 一 一 一 一 一 一 一 一 一 一 一 一 一 十 一 一 一 一 一 一 一 一 一 一 一 + 一 一 一 一 一 + 
1 000012 | 西方 经 济 学 | 刘 进 步 1 38 | 清华 大 学 出 版 社 | 2012-10-23| 20 | 
+ 一 一 一 一 一 一 + 一 一 一 一 一 一 一 一 一 一 一 一 + 一 一 一 一 一 一 + 一 一 一 一 一 一 二 一 一 一 一 一 一 一 一 一 一 一 一 一 一 十 一 一 一 一 一 一 一 一 一 一 一 + 一 一 一 一 一 十 


【实例 8-19】 在 book 表 中 查询 出 版 社 为 “清华 大 学 出 版 社 ”“ 北 京 邮电 大 学 出 版 
社 ” 或 “高 等 教育 出 版 社 ” 的 所 有 信息 。 
SELECT * FROM book WHERE publish=' 清 华 大 学 出 版 社 ' OR publish=' 高 等 教育 出 版 社 '; 


运行 结果 如 下 : 

+ 一 一 -一 一 一 一 二 一 一 一 一 一 一 一 一 一 一 一 一 一 一 一 一 十 一 一 一 一 一 一 一 一 一 + 一 一 一 一 一 一 十 一 一 一 一 一 一 一 一 一 一 一 一 十 一 一 一 一 一 一 一 一 一 一 + 一 一 一 一 一 一 十 

| bookid | bookname | editor | price| publish | pubdate | | 

+ 一 一 一 一 一 一 二 -一 一 一 一 一 一 一 一 一 一 一 一 一 一 一 二 一 一 一 一 一 一 一 一 一 十 一 一 一 一 一 一 十 一 一 一 一 一 一 一 一 一 一 一 一 十 一 一 一 一 一 一 一 一 一 一 二 -一 一 一 一 一 十 
000012 | 西方 经 济 学 | 刘 进 步 ”| ”38 | 清华 大 学 出 版 社 | 2012-10-23| 20 | 
000002 | VB 程序 设计 | 刘 艺 华 1 ”28 | 高 等 教育 出 版 社 | 2009-08-02| 4 1 


000007 | 高 等 数学 (第 四 版 下 ) | 同济 大 学 | ”30 | 高 等 教育 出 版 社 | 2000-01-08| 49 | 


| 

| 

| 000006 | 高 等 数学 (第 四 版 上 ) | 同济 大 学 | ”33 | 高 等 教育 出 版 社 | 2000-01-08| 79 | 
| 

| 000001 | matlab 与 绘图 1 张强 民 1 ”38 | 清华 大 学 出 版 社 | 2011-12-101 10 | 


【实例 8-20】 在 book 表 中 查询 图 书 价格 介 于 25 一 35 之 间 的 所 有 图 书信 息 。 


SELECT * FROM book WHERE price BETWEEN 25 AND 35; 


等 价 于 : 

SELECT * FROM book WHERE price>=25 and price<=35; 

运行 结果 如 下 

=== 二 === 一 一 一 一 一 二 和 二 
| bookid | bookname | editor | price | publish | pubdate Fe 
= 一 二 4 一 = 二 一 一 一 十 
1 000002 | 码 程 序 设计 1 刘 艺 华 1 ”28 | 高 等 教育 出 版 社 | 2009-08-02 | 41 

| 000005 | 计算 机 网 络 基础 | 文 几 妆 1 ”30 | 北京 邮电 出 版 社 | 2012-08-12 | 19 | 

1 000006 | 高 等 数学 (第 四 版 上 ) | 同济 大 学 | ”33 | 高 等 教育 出 版 社 | 2000-01-08 | 79 1 

1 000007 | 高 等 数学 (第 四 版 下) | 同济 大 学 | ”30 | 高 等 教育 出 版 社 | 2000-01-08 | 49 | 

1 000008 | 大 学 英语 1 赵 乐 楚 ”| ”34 | 北京 外 国语 出 版 社 | 2014-06-18 | 17 1 

1 000010 | 机 械 制 图 1 张 龙 | 35 | 机 械 工业 出 版 社 | 2012-04-10 | 21 1 
0 
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号 提示: 


e BETWEEN 后 面 是 范围 的 下 限 ( 即 最 小 值 )，AND 后 面 是 范围 的 上 限 ( 即 
最 大 值 )。 

BETWEEN...AND 的 一 般 格式 为 列 名 | 表达 式 BETWEEN 下 限 值 AND 
上 限 值 。 

NOT BETWEEN...AND 的 一 般 格 式 为 列 名 | 表达 式 NOT BETWEEN 下 


限 值 AND 上 限 值 。 


【实例 8-21】 在 book 表 中 ， 查 询 出 版 社 为 “水 电 出 版 社 ”“ 机 械 工业 出 版 社 ” 和 
“高 等 教育 出 版 社 ” 的 bookname、publish 等 字段 的 信息 。 


SELECT bookname,publish FROM Book WHERE publish in(' 水 电 出 版 社 ', ' 机 械 工业 出 
版 社 ',' 高 等 教育 出 版 社 ' ) ; 


等 价 于 : 
SELECT bookname,publish FROM Book WHERE publish=' 水 电 出 版 社 ' or publish=' 
机 械 工业 出 版 社 ' or publish=' 高 等 教育 出 版 社 '; 


二 一 一 一 一 一 一 一 一 一 一 一 一 一 一 + 
| publish 
二 一 一 一 一 一 一 一 一 一 一 一 一 一 一 + 
1 高 等 教育 出 版 社 | 
1 机 械 工 业 出 版 社 | 


| bookname 
和 
1 VB 程序 设计 

1 计算 机 审计 基础 


| 大 学 语文 
| 高 等 数学 (第 四 版 上 ) 
| 高 等 数学 (第 四 版 下 ) 
| 机 械 制 图 


三 二 二 二 三 三 二 二 二 二 二 二 二 二 二 二 


False。 


( 列 名 | 表 


SELECT * FROM book 


| bookid | bookname 


+ 一 一 一 一 一 一 一 一 十 一 一 一 一 一 一 一 一 一 一 


1 000012 | 西方 经 济 学 


1 水 电 出 版 社 | 
1 高 等 教育 出 版 社 | 
1 高 等 教育 出 版 社 | 
1 机 械 工业 出 版 社 | 


二 一 一 一 一 一 一 一 一 一 一 一 一 一 一 + 


当 列 值 (或 表达 式 ) 与 IN 集合 中 的 某 个 常量 值 相 等 时 ， 则 结果 为 True。 
当 列 值 (或 表达 式 ) 与 IN 集合 中 的 任何 一 个 常量 值 不 相等 时 ， 则 结果 为 


IN 的 条 件 表 达 式 等 价 于 条 件 表达 式 


达 式 = 常量 1) OR ( 列 名 | 表达 式 = 常 量 2) OR ..OR ( 列 名 | 表达 式 = 常 量 n) 
【实例 8-22】 在 book 表 中 ， 查 询 字段 editor 的 值 中 的 第 二 个 字 为 “ 进 ” 的 所 有 信息 。 
WHERE editor LIKE ' 进 %$'; 
4======== 二 En 二 一 = + 
| editor | price | publish | pubdate LxeE ll 
i 二 二 三 一 一 三 三 一 二 二 二 一 3 + 
1 刘 进 步 ”| ”38 1 清华 大 学 出 版 社 12012-10-23 | 20 | 
Se SRS De Te 二 站 


二 一 一 一 一 一 一 一 一 十 一 一 一 一 一 一 一 一 一 一 
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[ 读 提示 : 。 匹配 串 可 以 包含 常规 字符 和 通配符 (“ ”、“*#” )。 其 中 ，“ ”是 指 一 
个 任意 的 字符 ，“*” 是 指 任意 多 个 字符 。 
匹配 过 程 中 常规 字符 必须 与 字符 串 中 指定 的 字符 完全 匹配 。 
通配符 可 以 与 字符 串 的 任意 部 分 相 匹配 。 
3.， 对 查询 结果 进行 排序 
用 户 可 以 用 ORDER BY 子 句 对 查询 结果 按照 一 个 或 多 个 属性 列 的 升序 (ASC) 或 降序 
(DESC) 排 序 ， 省 略 则 为 升序 。 其 语法 格式 如 下 : 
ORDER BY < 列 名 1> [ASCIDESC] [,< 列 名 2> [ASCIDESC],…] 
【实例 8-23】 查询 book 表 中 的 所 有 信息 ， 要 求 查 询 结果 首先 按 pubdate 降序 排列 ， 
再 按 price 升序 排列 。 


SELECT * FROM book ORDER BY pubdate DESC, price RSC; 


000007 | 高 等 数学 (第 四 版 下 ) | 同济 大 学 | ”30 | 高 等 教育 出 版 社 | 2000-01-08 | 49 1 
000006 | 高 等 数学 (第 四 版 上 ) | 同济 大 学 | ”33 | 高 等 教育 出 版 社 | 2000-01-08 | 79 1 


运行 结果 如 下 : 

ee i el ee ee es 一 一 一 Se 
| bookid | bookname | editor | price | publish | pubdate EEC 
一 ee I Py 二 二 二 二 二 二 三 全 二 二 CR 二 四 
1 000008 | 大 学 英语 1 赵 乐 楚 。 ”| ”34 | 北京 外 国语 出 版 社 | 2014-06-18 | 17 1 
| 000009 | 计算 机 网 络 基础 1 谭 玉 龙 | ”48 | 水 利水 电 出 版 社 1 2013-03-12 | 39 | 
1 000012 | 西方 经 济 学 1 刘 进 步 ”| ”38 | 清华 大 学 出 版 社 | 2012-10-23 | 20 | 
1 000005 | 计算 机 网 络 基础 1 刘 峰 1 ”30 | 北京 邮电 出 版 社 | 2012-08-12 | 19 | 
1 000010 | 机 械 制 图 1 张 龙 ”| 35 | 机 械 工业 出 版 社 | 2012-04-10 | 21 1 
| 000001 | matlab 与 绘图 1 张强 民 ”| ”38 | 清华 大 学 出 版 社 1 2011-12-10 | 10 1 
| 000004 | 大 学 语文 1 谭 - 阔 ”| ”23 | 水 电 出 版 社 i2011=10=12 | -32 
| 000003 | 计算 机 审计 基础 1 张 浩 1 45 | 机 械 工业 出 版 社 | 2010-04-02 | 18 1 
1 000002 | VB 程序 设计 1 刘 艺 华 1 ”28 | 高 等 教育 出 版 社 | 2009-08-02 | 41 
| 

| 


4. 使 用 LIMIT 指定 行 数 查询 

在 使 用 SELECT 语句 进行 查询 时 ， 有 时 只 希望 列 出 查询 结果 中 的 某 几 条 记录 ， 而 不 是 
全 部 记录 ， 这 时 就 可 以 使 用 LIMIT 关键 字 来 限制 输出 的 结果 。 其 语法 格式 如 下 : 

LIMIT [start,]length 

@ start: 从 第 几 行 记录 开始 输出 。 默 认为 0， 表 示 第 一 条 记录 。 

@ length: 读 取 记录 的 行 数 。 

例如 ，LIMIT 2,4 是 指 从 第 3 条 记录 开始 ， 读 取 4 条 记录 。 

【实例 8-24】 查 询 book 表 前 5 条 记录 。 


SELECT * FROM book limit 0,5; 


运行 结果 如 下 : 


.(139\. 


mm PHP 动态 网 页 设计 教程 


士 一 一 一 一 一 一 一 一 二 一 一 一 一 一 一 一 一 一 一 一 一 一 十 一 一 一 一 一 一 一 十 一 一 一 一 一 一 十 一 一 一 一 一 一 一 一 一 一 一 一 一 一 十 一 一 一 一 一 一 一 一 一 一 一 十 一 一 一 一 一 + 
| bookid | bookname leditor| pricel publish | pubdate I ke 
十 一 一 一 一 一 一 一 一 4 一 一 一 一 一 一 一 一 一 一 一 一 一 十 一 一 一 一 一 一 一 十 一 一 一 一 一 一 十 一 一 一 一 一 一 一 一 一 一 一 一 一 一 十 一 一 一 一 一 一 一 一 一 一 一 十 一 一 一 一 一 十 
1 000012 | 西方 经 济 学 1 刘 进 步 | 38 1 清华 大 学 出 版 社 | 2012-10-23 | 20|1 
1 000002 | VB 程序 设计 ”| 刘 艺 华 | ”28 | 高 等 教育 出 版 社 | 2009-08-02 | 41l 
1 000003 | 计算 机 审计 基础 | 张 浩 1 ”45 | 机 械 工业 出 版 社 | 2010-04-02 | 181 
1 000004 | 大 学 语文 1 谭 一 阔 | 23 | 水 电 出 版 社 1 2011-10-12 | 32| 
1 000005 | 计算 机 网 络 基础 | 刘 峰 1 ”30 | 北京 邮电 出 版 社 | 2012-08-12 | 19| 
十 一 一 一 一 一 一 一 一 十 一 一 一 一 一 一 一 一 一 一 一 一 一 十 一 一 一 一 一 一 一 十 一 一 一 一 一 一 二 -一 一 一 一 一 一 一 一 一 一 一 一 一 二 二 二 一 二 下 
【实例 8-25】 在 book 表 中 ， 查 询 按 库 存量 (kcl) 降 序 排列 的 前 4 条 记录 。 
SELECT * FROM book order by kcl desc limit 4; 
运行 结果 如 下 : 
+--- 一 -一 一 二 一 一 一 一 一 一 一 一 一 一 一 一 一 一 一 一 一 二 一 一 一 一 一 一 一 一 一 + 一 一 一 一 一 一 十 一 一 一 一 一 -一 一 -一 一 -一 十 一 一 一 一 一 一 一 一 一 一 一 一 十 一 一 一 一 一 十 
| bookid | bookname | editor | Pricel publish | pubdate kcal 
+-- 一 一- 一 一 一 十 -一 一 一 一 一 一 一 一 一 一 一 一 一 一 一 一 + 一 一 一 一 一 一 一 一 一 + 一 一 一 一 一 一 二 一 一 一 一 一 一 一 一 一 一 一 一 一 十 一 一 一 一 一 一 一 一 一 一 一 一 十 一 一 一 一 一 十 
| 000006 | 高 等 数学 (第 四 版 上 ) | 同济 大 学 | ”33 | 高 等 教育 出 版 社 | 2000-01-08 | 79 | 


1 000007 | 高 等 数学 (第 四 版 下 ) | 同济 大 学 | ”30 | 高 等 教育 出 版 社 | 2000-01-08 | 49 | 
1 000009 | 计算 机 网 络 基础 | 谭 玉 龙 1 ”48 | 水 利水 电 出 版 社 | 2013-03-12 | 39 | 
| 000004 | 大 学 语文 1 谭 - 阔 | 23 1 水 电 出 版 社 | 2011-10-12 | 32 1 


5. 分 组 与 汇总 查询 
SELECT 查询 可 以 直接 对 查询 结果 进行 汇总 计算 ， 也 可 以 对 查询 结果 进行 分 组 计算 。 
在 查询 中 完成 汇总 计算 的 函数 称 为 聚合 函数 ， 实 现 分 组 查询 的 子 句 为 GROUP BY 子 句 。 
(1) 聚合 函数 与 汇总 查询 。 
聚合 函数 将 对 一 组 值 执行 计算 ， 并 返回 单个 值 。 常 用 的 聚合 函数 如 表 8-7 所 示 。 
表 8-7 常用 的 聚合 函数 





统计 元 组 个 数 

统计 一 列 中 值 的 个 数 

计算 一 列 值 的 总 和 (此 列 必须 为 数值 型 ) 
计算 一 列 值 的 平均 值 (此 列 必须 为 数值 型 ) 


COUNT(* 

COUNT( [ DISTINCT | ALL]< 列 名 | 表达 式 >) 

SUM ( [DISTINCT | ALL]< 列 名 | 表达 式 >) 

AVG ( [DISTINCT | ALL]< 列 名 | 表达 式 >) 

MAX ([ DISTINCT | ALL]< 列 名 | 表达 式 >) 求 一 列 值 中 的 最 大 值 

MIN ([ DISTINCT | ALL]< 列 名 | 表达 式 >) 求 一 列 值 中 的 最 小 值 

说 明 : 如 果 指 定 DISTINCT 关键 字 ， 则 表示 在 统计 时 要 取消 指定 列 的 重复 值 ， 如 果 不 
指定 DISTINCT 关键 字 和 指定 ALL 关键 字 ( 默 认 选 项 )， 则 表示 不 取消 重复 值 。 除 
COUNT(*) 外 ， 聚 合 函数 都 会 忽略 空 值 。 
【实例 8-26】 在 book 表 中 查询 记录 总 数 。 


SELECT COUNT(*) FROM book; 
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运行 结果 如 下 : 


[对 提示 :  “*” 表 示 以 任何 一 列 统计 都 可 以 。 
【实例 8-27】 在 book 表 中 查询 库存 量 (kcl) 的 总 和 及 平均 值 。 
SELECT SUM(kc]1),AVG(kcl1) FROM book; 
运行 结果 如 下 : 
十 -一 一 一 一 一 一 一 一 一 十 一 一 一 一 一 一 一 一 一 一 十 
| SUM(kcl) | RAVG(kcl) | 
十 一 一 一 一 一 一 一 一 一 一 十 一 一 一 一 一 一 一 一 一 一 十 
| 308 | 28.0000 | 
十 -一 一 一 一 一 一 一 一 一 十 一 一 一 一 一 一 一 一 一 一 十 


苇 提示 : SUMO 和 AVG0O 函 数 中 的 < 列 名 | 表达 式 > 必须 为 数值 型 数据 。 
【实例 8-28】 查 询 book 表 中 库存 量 (kcl) 的 最 大 值 和 最 小 值 。 


SELECT MAX(kc1), MIN(kcl1) FROM book; 


运行 结果 如 下 : 

二 -一 一 一 一 一 一 一 一 一 + 一 一 一 一 一 一 一 一 一 一 + 
| MAX(kcl1) | MIN(kc1) | 
二 -一 一 一 一 一 一 一 一 一 二 一 一 一 一 一 一 一 一 一 一 + 
1 | a | 
二 -一 一 一 一 一 一 一 一 一 二 一 一 一 一 一 一 一 一 一 一 十 


[对 提示 : MAXO、MINO 函 数 中 的 < 列 名 | 表达 式 > 可 以 是 数值 型 数据 和 字符 型 数据 。 


(2) GROUP BY 分 组 查询 与 计算 。 
聚合 函数 经 常 与 SELECT 语句 的 分 组 子 句 一 起 使 用 。 在 SQL 标准 中 ， 分 组 子 句 是 
GROUP BY，GROUP BY 分 组 查询 的 一 般 语法 格式 如 下 : 


SELECT < 分 组 依据 列 > [,.…,n] ,< 聚合 函数 > [,.…,n] 

FROM < 数据 源 > 

[WHERE < 检索 条 件 表达 式 >] 

GROUP BY < 分 组 依据 列 > [, . . . ,nj 

[HAVING < 检索 条 件 表 达 式 >] 

说 明 : 

®@ SELECT 子 句 和 GROUP BY 子 句 中 的 < 分 组 依据 列 >[,…,n] 是 相对 应 的 ， 分 组 依据 
列 可 以 只 有 一 列 ， 也 可 以 有 多 列 。 

@ WHERE 子 句 中 的 < 检索 条 件 表达 式 > 与 分 组 无 关 ， 用 来 做 筛选 条 件 FROM 子 句 
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中 指定 的 数据 源 所 产生 的 行 。 执 行 查询 时 ， 先 从 数据 源 中 筛选 
表达 式 > 的 元 组 ， 然 后 再 对 满足 条 件 的 元 组 进行 分 组 。 

@ GROUP BY 子 句 用 来 对 WHERE 子 句 的 输出 进行 分 组 。 

@ HAVING 子 句 用 来 从 分 组 的 结果 中 筛选 行 。 

【实例 8-29】 统 计 book 表 中 各 出 版 社 H 





版 的 图 书 数量 。 





bt 满足 < 检索 条 件 


SELECT publish,COUNT (DISTINCT bookid) FROM book GROUP BY Publish; 


运行 结果 如 下 : 


二 一 一 一 一 一 一 一 一 一 一 一 一 一 一 一 一 十 一 一 一 一 一 一 一 一 一 一 一 一 一 一 一 一 一 一 一 一 一 一 一 十 
| COUNT (DISTINCT bookid) | 
十 一 一 一 一 一 一 一 一 一 一 一 一 一 一 一 十 一 一 一 一 一 一 一 一 一 一 一 一 一 一 一 一 一 一 一 一 一 一 一 十 


| publish 


1 北京 外 国语 出 版 社 
1 北京 邮电 出 版 社 
1 机 械 工业 出 版 社 
1 水 利水 电 出 版 社 
1 水 电 出 版 社 

| 清华 大 学 出 版 社 
| 高 等 教育 出 版 社 


二 三 二 一 


一 加 


提示 : ”用 GROUP BY 分 组 时 ， 要 查询 显示 的 列 只 能 为 分 组 的 依据 列 和 聚合 函数 。 


【实例 8-30】 统 计 book 表 中 出 版 的 图 书 超过 2 本 的 出 版 社 。 


SELECT publish ,COUNT (DISTINCT bookid)as book id FROM book GROUP BY 
publish HAVING book id>2; 


运行 结果 如 下 : 
EE 


| publish 
es 


| 高 等 教育 出 版 社 


+ 一 -一 一 一 一 一 一 一 + 
book_id | 


提示 : ”。 HAVING 子 句 中 book id>2 是 分 组 后 的 元 组 应 该 满足 的 条 件 。 
e HAVING 与 GROUP BY 子 句 必须 一 起 使 用 ， 不 可 以 单独 使 用 。 


8.6.2 ”多 表 查 询 


多 表 查 询 是 基于 两 个 或 两 个 以 上 的 数据 表 的 查询 ， 这 些 数 据 表 必 须 在 某 些 字段 上 具有 
一 定 的 关联 关系 。 通 过 在 FROM 子 句 中 使 用 各 种 连接 (join) 运 算 ， 将 不 同 数据 表 中 的 记录 
组 合 起 来 。 在 MySQL 中 连接 分 为 : 内 连接 (inner join)、 外 连接 (outer join) 和 全 连接 (full 
join)， 外 连接 又 分 为 外 左 连接 (left join) 和 外 右 连接 (right join)， 简 称 左 连接 和 右 连 接 。 





(1) 内 连接 。 


内 连接 是 将 两 个 数据 表 中 满足 指定 连接 条 件 的 记录 连接 成 新 的 记录 和 集 ， 舍 弃 所 有 不 满 
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足 连接 条 件 的 记录 。 其 语法 格式 如 下 : 


FROM table namel [inner] join table name2 on < 连接 条 件 > 


(2) 外 连接 。 

外 连接 只 限制 一 个 数据 表 ， 对 另 一 个 数据 表 不 加 限制 (该 数据 表 中 的 记录 出 现在 结果 
集中 )。 

中 左 连 接 。 左 连接 数据 表 A 和 数据 表 B 意味 着 读 取 表 A 的 全 部 记录 按 指定 的 连接 
条 件 与 表 B 中 满足 连接 条 件 的 记录 进行 连接 。 若 表 B 中 没有 满足 连接 条 件 的 记录 ， 则 表 A 
中 相应 字段 填 入 NULL。 其 语法 格式 如 下 : 


FROM table namel left join table_name2 on < 连接 条 件 > 


@ 右 连 接 。 右 连接 数据 表 A 和 数据 表 B 意味 着 读 取 表 B 的 全 部 记录 按 指定 的 连接 
条 件 与 表 A 中 满足 连接 条 件 的 记录 进行 连接 。 若 表 A 中 没有 满足 连接 条 件 的 记录 ， 则 表 B 
中 相应 字段 填 入 NULL。 其 语法 格式 如 下 : 


FROM table_namel right join table_name2 on < 连接 条 件 > 


内 连接 与 外 连接 的 区 别 是 : 内 连接 将 去 除 所 有 不 符合 条 件 的 记录 ， 而 外 连接 则 保留 其 
中 部 分 记录 。 

左 连接 与 右 连接 的 区 别 是 : 如果 用 数据 表 A 左 连 接 数 据 表 B， 则 数据 表 A 中 的 全 部 记 
录 会 保留 在 结果 集中 ， 而 数据 表 B 中 只 有 符合 连接 条 件 的 记录 才 出 现在 结果 集中 ， 右 连接 
则 相反 。 

(3) 全 连接 。 

全 连接 也 称 交 叉 连接 ， 是 指 每 个 数据 表 的 每 条 记录 都 与 其 他 数据 表 中 的 所 有 记录 交 
又 ,产生 所 有 可 能 的 组 合 ， 也 就 是 所 谓 的 笛 卡 儿 积 。 两 个 分 别 有 50 条 记录 和 40 条 记录 的 
数据 表 执 行 全 连接 ， 可 能 会 得 到 一 个 具有 2000 条 记录 的 结果 。 

在 实际 应 用 中 ， 为 防止 查询 结果 过 大 ， 通 常 将 结果 集 减少 到 最 少 。 如 果 在 WHERE 子 
句 中 增加 一 条 使 各 表 在 某 些 列 上 进行 匹配 ， 这 个 连接 就 是 所 谓 的 同 值 连接 (equi-join)， 它 只 
选择 那些 在 指定 列 中 具有 相等 的 值 的 记录 。 

【实例 8-31】 从 book 表 和 borrow 表 中 查询 被 借 图 书 的 图 书 名 称 、 借 阅 时 间 。 
数据 表 borrow 的 表 结 构 如 表 8-8 所 示 。 


























表 8-8 表 borrow 的 字段 信息 











字 段 类 型 (长 度 ) 区 
cardid VARCHAR(10. 
bookid VARCHAR(8) 
bdate 
Idate 





borrow 表 的 记录 信息 如 表 8-9 所 示 。 
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表 8-9 表 borrow 的 记录 信息 























cardid bdate rdate 
stu000001 000001 2011-03-20 2017-04-20 
stu000001 000002 2011-03-20 2017-04-20 
stu000003 000004 2012-10-01 2012-10-25 
stu000002 000003 | 2012-09-08 2012-11-05 
stu000002 O000008 2011-05-08 2011-09-18 
stu000002 2010-10-09 2014-10-03 
stu000003 2013-11-02 2013-12-06 
stu000003 2012-05-12 2012-05-08 


Book 数据 表 的 记录 信息 如 表 8-10 所 示 。 
表 8-10 ”book 记录 信息 


bookid bookname editor | wis | -pubish | pubdate kcl 


000012 | 西方 经 济 学 刘 进 步 清华 大 学 出 版 社 | 2012-10-23 | 20 
000002 | VB 程序 设计 刘 艺 华 高 等 教育 出 版 社 。 | 2009-08-02 | 4 
000003 | 计算 机 审计 基础 张 浩 机 械 工 业 出 版 社 2010-04-02 | 18 
000004 | 大 学 语文 谭 一 阔 2011-10-12 | 32 
000005 | 计算 机 网 络 基础 刘 峰 北京 邮电 出 版 社 2012-08-12 | 19 


000006 | 高 等 数学 (第 四 版 上 ) | 同济 大 学 高 等 教育 出 版 社 2000-01-08_| 79 
000007 | 高 等 数学 (第 四 版 下 ) | 同济 大 学 高 等 教育 出 版 社 2000-01-08 | 49 

















000008 | 大 学 英语 赵 乐 楚 34 北京 外 国语 出 版 社 _| 2014-06-18 | 17 
000009 | 计算 机 网 络 基础 谭 玉 龙 48 水 利水 电 出 版 社 2013-03-12 | 39 
000010 | 机 械 制图 张 飞龙 35 机 械 工业 出 版 社 2012-04-10 | 21 
000001 | matlab 与 绘图 张强 民 38 清华 大 学 出 版 社 2011-12-10 | 10 








borrow 表 的 字段 bookid 与 8.4.1 所 创建 的 book 表 的 字段 bookid 具有 相同 的 内 容 ， 因 
此 可 以 据 此 进行 book 表 和 borrow 表 的 联合 查询 。 
book 表 与 borrow 表 的 内 连接 : 


SELECT book.bookname,borrow.bdate from book inner join borrow on 
book.bookid=borrow.bookid; 


运行 结果 如 下 : 

3 1 + 
| bookname | bdate | 
====>======== 一 一 二 二 三 一 三 三 + 
1 VB 程序 设计 | 2011-03-20 | 
1 VB 程序 设计 | 2012-05-12 | 


1 计算 机 审计 基础 “| 2012-09-08 | 


sr wc 10 人 





| 计算 机 审计 基础 “| 2013-11-02 | 
1 大 学 语文 W2072 T0010 
1 计算 机 网 络 基础 1 2010-10-09 | 
| 大 学 英语 | 2011-05-08 | 
| matlab 与 绘图 | 2011-03-20 | 
十 一 一 一 一 一 一 一 一 一 一 一 一 一 一 十 一 一 一 一 一 一 一 一 一 一 一 一 + 
book 表 与 borrow 表 的 左 连 接 : 


SELECT book.bookname,borrow.bdate from book left join borrow on 
book.bookid=borrow.bookid; 


高 等 数学 (第 四 版 上 ) ”| NULL | 
高 等 数学 (第 四 版 下 ) “1 NULL | 


运行 结果 如 下 

十 一 一 一 一 一 一 一 一 一 一 一 一 一 一 一 一 一 一 一 一 二 一 一 一 一 一 一 一 一 一 一 一 一 十 
| bookname | bdate | 
十 一 一 一 一 一 一 一 一 一 一 一 一 一 一 一 一 一 一 一 一 十 一 一 一 一 一 一 一 一 一 一 一 一 十 
| matlab 与 绘图 | 2011-03-20 | 
1 VB 程序 设计 | 2011-03-20 | 
| 大 学 语文 | 2012-10-01 | 
1 计算 机 审计 基础 | 2012-09-08 | 
| 大 学 英语 | 2011-05-08 | 
1 计算 机 网 络 基础 | 2010-10-09 | 
| 计算 机 审计 基础 | 2013-11-02 | 
1 VB 程序 设计 | 2012-05-12 | 
| 西方 经 济 学 | NULL 1 
1 

| 

1 计算 机 网 络 基础 | NULL 1 
| 机 械 制图 | NULL 1 
十 一 一 一 一 一 一 一 一 一 一 一 一 一 一 一 一 一 一 一 一 二 一 一 一 一 一 一 一 一 一 一 一 一 十 
book 表 与 borrow 表 的 右 连接 : 


SELECT book.bookname,borrow.bdate from book right join borrow on 
book.bookid=borrow.bookid; 


运行 结果 如 下 

+ 一 一 一 一 一 一 一 一 一 一 一 一 一 二 一 一 一 一 一 一 一 一 一 一 一 一 + 
| bookname | bdate | 
+ 一 一 一 一 一 一 一 一 一 一 一 一 一 一 二 一 一 一 一 一 一 一 一 一 一 一 一 + 
1 VB 程序 设计 | 2011-03-20 | 
1 VB 程序 设计 | 2012-05-12 | 
| 计算 机 审计 基础 | 2012-09-08 | 
1 计算 机 审计 基础 “| 2013-11-02 | 
1 大 学 语文 | 2012-10-01 | 
1 计算 机 网 络 基础 | 2010-10-09 | 
| 大 学 英语 | 2011-05-08 | 
1 matlab 与 绘图 | 2011-03-20 | 
二 二 + 
book 表 与 borrow 表 的 同 值 连接 : 
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SELECT book.bookname,borrow.bdate from book,borrow WHERE 
book .bookid=borrow .bookid; 


运行 结果 如 下 : 

es i 
| bookname | bdate | 
十 一 一 一 一 一 一 一 一 一 一 一 一 一 一 十 一 一 一 一 一 一 一 一 一 一 一 一 + 
1 VB 程序 设计 | 2011-03-20 | 
1 VB 程序 设计 | 2012-05-12 | 
1 计算 机 审计 基础 1 2012-09-08 | 
1 计算 机 审计 基础 1 2013-11-02 | 
| 大 学 语文 | 2012-10-01 | 
1 计算 机 网 络 基础 | 2010-10-09 | 
| 大 学 英语 | 2011-05-08 | 
| matlab 与 绘图 | 2011-03-20 | 
二 一 一 一 一 一 一 一 一 一 一 一 一 一 一 十- 一 一 一 一 一 一 一 一 一 一 一 十 


8.7 phpMyAdmin 图 形 化 管理 工具 
8.7.1 启动 phpMyAdmin 


以 上 介绍 的 是 利用 命令 语句 对 MySQL 数据 库 、 数 据 表 和 记录 进行 操作 的 过 程 。 对 
MySQL 的 操作 也 可 以 使 用 XAMPP 系统 提供 的 pppMyAdmin 图 形 界面 来 进行 数据 库 、 数 
据 表 和 记录 等 一 系列 管理 工作 。 

使 用 phpMyAdmin 的 图 形 界面 首先 需要 启动 Apache 和 MySQL， 然 后 打开 浏览 器 ， 在 
址 栏 中 输入 http://127.0.0.1/phpmyadmin 或 者 输入 http://localhost/phpmyadmin， 就 可 以 进入 
phpMyAdmin 的 操作 界面 ， 如 图 8-11 所 示 。 








CD locibor hoeres 二 
phpMyAdmin EEE 
@e Fr 


小 ea = NERA :rb rode 











月 站 了 -ccc 于 这 站 计 2 光 生生 过 人 8 Wd 中富 这 个 生 二 厅 ， 这 可 关 和民 ， 姑 人 过 
全 net” 同 疡 训 一 个 下 主人 朵 ， 




















8-11 phpMyAdmin 启动 界面 
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8.7.2 数据库 管 理 





进入 管理 界面 之 后 ， 在 界面 左 侧 列 出 的 是 已 经 创建 的 数据 库 ， 在 这 里 可 以 进行 数据 库 
的 创建 、 维 护 等 操作 。 


1. 创建 数据 库 


单 击 左 侧 栏目 上 方 的 “新 建 ” 超 链接 ， 则 在 右 侧 弹出 创建 数据 库 的 窗口 ， 如 图 8-12 
所 示 。 





人 


it 








-因而 可 





图 8-12 ”创建 数据 库 
在 右 侧 窗口 内 的 “新 建 数据 库 ” 下 填写 数据 库 的 名 称 ， 单 击 “ 排 序 规则 ”下 拉 框 ， 选 
择 数据 库 的 字符 集 。 最 后 ， 单 击 “ 创 建 ”按钮 即 完成 数据 库 的 创建 工作 。 
2. 数据 库 的 维护 
在 左 侧 窗口 内 单 击 某 数据 库 的 名 称 ， 则 右 侧 窗口 内 会 显示 该 数据 库 的 相关 信息 ， 如 数 


据 库 的 相关 操作 链接 (SQL、 搜 索 、 查 询 、 导 出 、 导 入 、 操 作 、 权 限 、 程 序 和 更 多 等 )、 所 
包含 的 数据 表 及 相关 操作 (浏览 、 结 构 、 搜 索 、 插 入 、 清 空 和 删除 等 )， 如 图 8-13 所 示 。 





SA 


fn a sm ra 小 多 
* Me 和 A Pn le i 


th 吉 四 日 守 和 











8-13 ”数据 库 维护 
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8.7.3 ”数据 表 管理 

在 左 侧 窗口 内 ， 单 击 某 数据 库 左 侧 的 图 标 困 ， 则 会 显示 该 数据 库 所 包含 的 数据 表 。 在 
此 可 以 进行 数据 表 的 新 建 、 维 护 等 操作 。 
1. 新 建 数据 表 


单 击 数据 库 名 下 方 的 “新 建 ” 超 链接 ， 则 在 右 侧 窗口 内 显示 创建 数据 表 的 相关 操作 界 
， 如 字段 的 名 称 、 类 型 、 长 度 等 ， 如 图 8-14 所 示 。 























Was 








图 8-14 创建 新 表 


2. 数据 表 的 维护 


在 左 侧 窗 口内 单 击 某 数据 表 的 名 称 ， 则 右 侧 窗 口内 会 显示 该 数据 表 的 记录 信息 、 数 据 
表 和 记录 的 相关 操作 的 链接 等 ， 如 图 8-15 所 示 。 





+ boat shawn 

phpMyAdmin 下 
人 Av Oe 

uy 
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图 8-15 数据 表 维 护 
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8.8 综合 实 训 案 例 


本 节 主 要 讲解 利用 phpMyAdmin 图 形 化 管理 工具 创建 数据 库 及 数据 表 的 操作 过 程 。 
1. 实 训 目 的 


掌握 利用 phpMyAdmin 图 形 化 管理 工具 来 对 数据 库 的 管理 、 数 据 表 的 管理 、 用 户 管 
理 、 数 据 的 导入 /导出 、SQL 查询 等 。 
2. 实 训 内 容 

















创建 商品 销售 数据 库 spxs， 在 该 数据 库 下 创建 3 个 数据 表 : 商品 表 (spb)、 客 户 表 (khb) 
和 销售 表 (xsb)。 其 中 ， 商 品 表 的 表 结 构 如 表 8-11 所 示 ， 客 户 表 的 表 结 构 如 表 8-12 所 示 ， 
销售 表 的 表 结 构 如 表 8-13 所 示 。 
表 8-11 商品 表 (spb) 的 表 结构 信 息 


字段 名 称 字段 类 型 /长 度 





y 


表 8-12 ”客户 表 (khb) 的 表 结 构 信 息 


ET 
[TI 











字段 名 称 



















Varchar(10) 商品 名 称 
XSIq Date | 商品 类 别 
xssl | 销售 数量 





销售 价格 


商品 表 的 记录 信息 如 表 8-14 所 示 ， 客 户 表 的 记录 信息 如 表 8-15 所 示 ， 销 售 表 的 记录 
信息 如 表 8-16 所 示 。 
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表 8-14 商品 表 的 记录 信息 

















2015-3-4 
2016-1-8 


2016-2-7 
2012-12-7 


3. 实 训 步骤 


@ 进入 phpMyAdmin 图 形 管理 界面 。 启 动 XAMPP 控制 面板 ， 


图 形 管理 工具 界面 。 


销售 价格 


启动 Apache 和 
MySQL， 打 开 浏 览 器 ， 在 地 址 栏 输入 http:/WlocalhosVphpmyadmin， 即 可 进入 phpMyAdmin 


@ 创建 数据 库 spxs。 在 左 侧 单 击 “ 新 建 ” 超 链 接 ， 在 右 侧 的 “新 建 数据 库 ” 下 方 的 
文本 框 中 输入 数据 库 名 称 spxs， 单 击 “ 排 序 规则 ”下 拉 框 ， 选 择 字符 集 utf8_unicode_ci, 


最 后 单 击 “ 创 建 ” 按 钮 ， 如 图 8-16 所 示 。 











@ ”创建 数据 表 。 在 左 侧 单 击 数据 库 名 spxs， 然 后 在 右 侧 的 “名 字 ” 栏 目 中 输入 所 创 





建 数据 表 的 名 称 ， 以 及 该 表 的 字段 数量 ， 再 单 击 “ 执 行 ”按钮 进入 创建 表 





所 示 。 在 创建 数据 表 的 操作 界面 上 依次 输入 表 的 字段 名 称 、 字 段 类 型 、 


图 8-18 所 示 。 依 次 创建 数据 表 商 品 表 (spb)、 客 户 表 (khb) 和 销售 表 (xsb)。 


的 界 








本 ， 如 图 8-17 


字段 长 度 等 ， 如 


外 输入 记录 。 在 左 侧 单 击 数据 表 的 名 称 ， 在 右 侧 窗口 内 ， 可 以 单 击 “ 插 入 ”或 “ 导 


入 ”等 链接 ， 将 数据 录入 数据 表 中 。 
/150\. 








phpMyAdmin 
全 日 中 闪 @ 
近期 访问 表 收 藏 夫 







数据 库 























一 局 新 奸 
曲 回 beamerage 

庙 .infomation schema 忆 新 建 雪 据 库 “加 
nysal spxs utf8_unicoce_ci 加 创建 

转 可 performance_schena 

轩 - 3 phpmyadnin 数据 库 = 排序 规则 











回回 test latinl_swedish_ci 三 检查 权限 





目 bodmanage 





infomation_schena 。 atfB_general_ei a 检查 权限 





CDENM latinl_swedish_ci a 检查 权限 ~ 


8-16 创建 数据 库 spxs 





hlocalhost 
€ 3 © |D localhost/phpm 
phpMyAdmin 
全 日 申 帘 9 查 族 号 Ss 加 SA 咏 投 作 
近期 访问 “ 表 收 藏 大 





| 数据 库 中 没有 丧 。 





局 新 于 


可 加 Doamemaee | 加 亲 建 数据 夫 | 
四 国 infomation shens 
日 回 we 


南 可 performance_schena 
用 phpmyadmin 

局 spm 

test 





8-17 ”创建 新 数据 表 spb 


Y locelhost /phos 








phpMyAdmin 
pp EEC 

an | = 而 

es 

wom 和 an a/ mu Mam mu 和 Ar | 

a 

Oe 下 Wie = i a | 

ri 

a 

p 

a ee Cr 3 > - 有 7 ] 


Heth rm Gar 





| Sat 表 本。 信友 


8-18 ”输入 新 表 字 段 信息 
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本 章 小 结 


本 章 介 绍 了 MySQL 服务 器 在 XAMPP 系统 下 的 启动 、 连 接 和 关闭 操作 ， 并 详细 介绍 
了 MySQL 字符 集 设 置 ， 数 据 库 的 管理 ， 数 据 表 的 管理 ， 数 据 记 录 新 增 、 修 改 、 更 新 ， 数 
据 查 询 等 知识 。 同 时 还 介绍 了 利用 phpMyAdmin 图 形 化 管理 工具 来 管理 数据 库 和 数据 表 的 
方法 ， 





习 题 


为 以 下 各 题写 出 正确 的 SQL 命令 。 

1. 设 有 订单 表 order( 订 单 号 、 客 户 号 、 职 员 号 、 签 订 日 期 、 金额 )， 查 询 2011 年 所 签 
订单 的 信息 ， 并 按 金 额 降序 排序 。 

2. 设 有 学 生 表 S( 学 号 、 姓 名 、 性 别 、 年 龄 )、 课 程 表 C( 课 程 号 、 课 程 名 、 学 分 ) 和 学 生 
选课 表 SC( 学 号 、 课 程 号 、 成 绩 )， 检 索 学 号 、 姓 名 和 学 生 所 选课 程 的 课程 名 和 成 绩 。 

3. 设 有 学 生 ( 学 号 、 姓 名 、 性 别 、 出 生日 期 ) 和 选课 (学 号 、 课 程 号 、 成 绩 ) 两 个 表 ， 计 
算 刘 明 同 学 选修 的 所 有 课程 的 平均 成 绩 。 

4. 设 有 学 生 ( 学 号 、 姓 名 、 性 别 、 出 生日 期 ) 和 选课 (学 号 、 课 程 号 、 成 绩 ) 两 个 表 ， 查 
询 选修 课程 号 为 101 的 得 分 最 高 的 同学 。 

5. 设 有 选课 (学 号 、 课 程 号 、 成 绩 ) 表 ， 插 入 一 条 记录 到 “选课 ” 表 中 ， 学 号 、 课 程 号 
和 成 绩 分 别 是 02080111、103 和 80。 

6. 设 有 歌手 表 ( 歌 手 号 、 姓 名 、 最 后 得 分 ) 和 评分 表 ( 歌 手 号 、 分 数 、 评 委 号 )， 每 个 歌 
手 的 最 后 得 分 是 所 有 评委 给 出 的 分 数 的 平均 值 ， 计 算 歌 手 的 最 后 得 分 。 
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本 章 要 点 

@ ”PHP 操作 MySQL 数据 库 常 用 的 函数 

@ ”PHP 对 数据 的 插入 、 修 改 、 删 除 、 查 询 的 操作 函数 

学 习 目标 

@ 掌握 PHP 连接 MySQL 的 步骤 及 函数 

@ 掌握 PHP 对 数据 进行 插入 、 人 和 修改、 删除 、 查 询 等 操作 的 函数 


9.1 PHP 操作 MySQL 数据 库 的 函数 


PHP 中 提供 了 很 多 操作 MySQL 数据 库 的 函数 ， 利 用 这 些 函 数 ， 可 以 完成 对 MySQL 
数据 库 的 各 种 操作 。PHP 5.0 之 后 的 版 本 ，PHP 推荐 使 用 mysqli 系列 函数 来 操作 MySQL 
数据 库 ， 本 教材 主要 介绍 mysqli 系列 函数 。 


9.1.1 连接 MySQL 数据 库 


在 操作 MySQL 数据 库 之 前 ， 首 先 要 确保 已 成 功 连接 MySQL 数据 库 。 连 接 MySQL 数 
据 库 服务 器 常用 的 函数 是 mysqli_connect()。 函 数 的 语法 格式 如 下 : 

mysqli_connect (string host, string username, string password, string database) 

函数 功能 :通过 PHP 程序 连接 MySQL 数据 库 服务 器 。 

如 果 连 接 MySQL 数据 库 服 务 器 成 功 ， 函 数 返 回 值 为 一 个 MySQL 服务 器 连接 标识 
(Link_identifieD， 和 否则 返回 值 为 FALSE。 

函数 的 参数 说 明 如 表 9-1 所 示 。 

表 9-1 mysqli_connect() 函 数 的 参数 说 明 





说 明 
MySQL 数据 库 服 务 器 的 IP 地 址 或 主机 名 ， 默 认 端 口 值 为 3306( 常 省 略 ) 
连接 MySQL 数据 库 服 务 器 的 用 户 名 
Password 连接 MySQL 数据 库 服务 器 的 密码 
database 所 要 连接 的 MySQL 数据 库 名 称 


【实例 9-1】 实 现 连接 本 地 MySQL 数据 库 服务 器 (假设 MySQL 数据 库 服务 器 中 已 创 
建 数据 库 school)。 


<?php 
$host="localhost"; //MYSQL 数据 库 服务 器 的 地 址 
$username="root"; // 登 录 数据 库 服务 器 的 用 户 名 
$password=""; / /登录 数 据 库 服务 器 的 密码 
$database="school™; // 登 录 的 数据 库 名 称 


$conn=mysqli_connect ($host, $username, $password, $database); 


host 





username 
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有 时 为 了 能 够 方便 地 查询 到 因 连 接 数 据 库 失 败 而 出 现 的 错误 ， 常 常 采 用 die0O 函 数 生成 
错误 处 理 机 制 。 
首先 使 用 mysqli_ermo() 函 数 判断 连接 MySQL 服务 器 是 否 成 功 ， 若 不 成 功 ， 则 浏览 
上 会 显示 “Warming: mysqli_connect()...” 的 字样 ， 此 时 可 以 使 用 mysqli_connect_error() 函 
数 提取 mysqli_connect0 函 数 的 错误 信息 ; 如 果 连 接 成 功 ， 则 mysqli_connect_error() 函 数 返 
回 空 字符 串 。 实 例 9-1 的 PHP 程序 可 以 写 为 ; 
<?php 
$host="localhost"; 
$username="root"; 
$password=""; 
$database="school™"; 
$conn=mysqli_connect ($host, $username, $password, $database); 
if (mysqli_connect_errno()) 
die ("MySQL 数据 库 连接 失败 ! " .mysqli_connect_error ()); 














Epa 


9.1.2 ”设置 数据 库 字 符 集 


我 们 在 执行 PHP 程序 显示 数据 库 的 内 容 时 ， 有 时 会 发 现在 浏览 器 页 面 上 本 来 应 该 显示 
的 中 文字 符 却 变 成 了 一 堆 乱 码 ， 这 是 因为 MySQL 数据 库 、PHP 程序 、HTML 页 面 以 及 浏 
览 器 所 使 用 的 字符 集 不 一 致 造成 的 。MySQL 数据 库 默 认 使 用 的 字符 集 是 utf-8， 我 们 使 用 
的 正 浏览 器 默认 使 用 的 字符 集 是 简体 中 文字 符 集 gb2312， 有 时 候 HTML 页 面 使 用 的 也 是 
gb2312 字符 集 ， 这 就 涉及 PHP 程序 中 编码 的 转换 问题 。 

在 PHP 程序 里 需要 将 MySQL 数据 库 的 字符 集 character_set_database、 客 户 端 字 符 集 
character_set_client 、 数 据 库 连接 字符 集 character set connection 和 结果 字符 集 
character_set_result 设置 为 一 个 统一 的 简体 中 文字 符 集 ， 这 样 才能 避免 在 浏览 器 页 面 上 出 现 
乱码 的 现象 。 

一 般 为 了 便于 PHP 程序 调试 、 运 行 ， 字 符 集 可 以 统一 设置 为 gb2312、gbk 或 utf-8。 
调用 PHP 函数 mysqli query0O 就 可 以 将 character_set_database 、character_set_client、 
character_set_connection 和 character set result 的 字符 集 设 置 为 所 需 的 字符 集 。 
mysqli_query0) 函 数 的 调用 位 置 一 般 位 于 连接 MySQL 数据 库 的 命令 之 后 ， 调 用 的 命令 格式 
如 下 : 


mysqli_query ($conn,"set names gb2312"); 


为 了 方便 连接 MySQL 数据 库 ， 可 以 将 实例 9-1 的 程序 单独 写成 一 个 PHP 程序 文件 ( 比 
如 命名 为 connect mysqlLphp)， 需 要 连接 MySQL 数据 库 时 ， 就 在 PHP 程序 文件 中 使 用 
include() 函 数 或 include_once() 函 数 调用 该 程序 文件 。connect_mysql.php 程序 文件 完整 的 内 
容 如 下 : 








<?php 
global $conn; // 数 据 库 连 接 标 识 符 
$host="localhost"; //MySQL 服务 器 地 址 
$username="root"; // 登 录 MySQL 服务 器 的 用 户 名 
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$password=""; // 登 录 MySQL 服务 器 的 密码 
$database="school"; // 要 操作 的 数据 库 
$conn=mysqli_connect ($host, $username, $Spassword, $database); 
mysqli query($conn, "set names gb2312"); 
if (mysqli connect errno ($conn)) 
die ("MySQL 服务 器 连接 失败 ! " .mysqli_connect_error ()); 
本 


9.1.3 执行 SQL 语句 


在 连接 MySQL 服务 器 、 设 置 字符 集 后 ， 就 可 以 在 PHP 程序 中 向 MySQL 服务 器 发 送 
SQL 语句 或 MySQL 命令 了 。 在 PHP 程序 中 常常 采用 mysqli_query0 函 数 向 MySQL 服务 
器 发 送 操作 命令 ， 语 法 格式 如 下 : 

mysqli_query (connection, query[, resultmode]) 

函数 的 参数 说 明 如 表 9-2 所 示 。 

表 9-2 mysqli_query() 函 数 的 参数 说 明 


参 数 说 明 
connection MySQL 服务 器 的 连接 ID 
ue 向 MySQL 服务 器 发 送 的 SQL 语句 或 MySQL 命令 
可 选 。 是 一 个 常量 ， 可 以 是 MYSQLI_USE_RESULT( 适 用 于 大 量 数据 的 检索 ) 或 
resultmode 


MYSQLI_STORE_RESULT( 默 认 ) 





函数 的 返回 值 : 针对 成 功 的 select、show、describe 或 explain 查询 ， 将 返回 一 个 
mysqli_result 对 象 集 。 其 他 操作 (如 delete、update、insert 等 SQL 语句 ) 若 成 功 ， 将 返回 
TRUE; 如 果 失 败 ， 则 返回 FALSE。 

1. 发 送 insert、update 或 delete 语句 

使 用 mysqli_query0 函 数 向 MySQL 服务 器 发 送 insert、update 或 delete 命令 语句 后 ， 
可 以 使 用 mysqli_affected_rows() 函 数 查 看 SQL 语句 影响 的 表 记 录 行 数 。mysqli_affected_ 
rows() 函 数 的 语法 格式 如 下 : 

mysqli_affected_ rows (connection) 

函数 功能 : 取得 函数 最 近 一 次 与 表 操 作 所 影响 的 记录 行 数 。 

【实例 9-2】 向 school 数据 库 的 student 表 中 插入 数据 。student 表 的 结构 如 表 9-3 所 示 。 
表 9-3 student 表 的 结构 


字段 名 称 字段 类 型 及 长 度 字段 含义 
xh vechar,20 学 号 
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<?php 
include once ("connect mysql.php"); 
header ("Content-Type:text/html;charset=gb2312"); 
$sql="insert into student (xh,xm,bj,cj) values('140123101', ' 王 浩 '"，' 机 
械 2015=17 90) "> 
$result=mysqli query ($conn, $sql); 
if($result) 
echo "插入 记录 的 行 数 :" .mysqli_affected_rows ($conn); 
el1se 
echo" 数 据 插入 失败 1"; 


Re 


【实例 9-3】 将 student 表 中 学 号 为 140123105 的 学 生 的 班级 改 为 “信息 2014-1”。 


<?php 
include_once ("connect mysql.php"); 
header ("Content-Type:text/html;charset=gb2312"); 
$s_xh="'140123105"'; 
$s_bj=' 信 息 2014-1'; 
$sql="update student set bj= '$s_bj' where xh='$s_xh'"; 
$result=mysqli_query ($conn, $sql1); 
if($result) 
echo "记录 修改 成 功 ! "; 
else 
echo "记录 修改 不 成 功 ! "; 
全 


【实例 9-4】 删 除 student 表 中 学 号 为 140123105 的 学 生 记录 。 


<?php 
include once ("connect mysql .php"); 
header ("Content-Type:text/html;charset=gb2312"); 
$s_xh="140123105"; 
$sql="delete from student where xh='$s_xh'"; 
$result=mysqli_query ($conn, $sql); 
if($result) 
echo "记录 删除 成 功 ! "; 
else 
echo "记录 删除 不 成 功 ! "; 
二 


2. 发 送 select 语句 


使 用 mysqli_query0 函 数 向 MySQL 服务 器 发 送 select 命令 语句 后 ，mysqli_queryO 函 数 
将 得 到 一 个 结果 集 (result) 数 据 ， 此 时 可 以 使 用 mysqli_ num _rows() 函 数 查 看 该 结果 集 的 记录 
行 数 。mysqli_num _rows() 函 数 的 语法 格式 如 下 : 


int mysqli_ num rows (result) 


函数 的 参数 说 明 如 表 9-4 所 示 。 


(57. 


mm 区 >》 PHP 动态 网 页 设计 教程 


表 9-4 _ mysqlinum_rows() 函 数 的 参数 说 明 





由 mysqli_query0 返 回 的 结果 集 标识 符 


函数 的 返回 值 : 返回 结果 集中 记录 的 数量 。 
【实例 9-5】 查 询 student 表 的 记录 数 。 


<?php 
include once ("connect mysql.php"); 
header ("Content-Type:text/html;charset=gb2312"); 
$sql="select * from student"; 
$result=mysqli query ($conn, $sql); 
$row_count=mysqli_num rows ($result); 
echo "记录 数 : " .$row_count; 





> 


9.1.4 遍历 结果 集 

在 使 用 mysqli_query0 函 数 取 得 查询 的 结果 集 后 ， 就 可 以 使 用 mysqli_fetch_rowO 函 
数 、mysqli_fetch_array0 函 数 和 mysqli_fetch_object0 函 数 遍 历 结果 集中 的 数据 。 

1. mysqli_fetch_row() 函 数 

函数 的 语法 格式 如 下 

array mysqli fetch row (result) 

函数 的 参数 说 明 如 表 9-5 所 示 。 

表 9-5 mysqli_fetch_row() 函 数 的 参数 说 明 





result 由 mysqli_query0 函 数 返回 的 结果 集 标识 符 


函数 功能 : 从 结果 集 result 中 获取 一 行 记录 ， 并 将 该 行 记录 生成 一 个 数组 ， 数 组 元 素 
的 键 从 0 开始 ， 数 组 元 素 的 值 依次 为 select 语句 中 “字段 列表 ”的 值 。 若 结果 集 result 中 
没有 记录 ， 则 函数 的 返回 值 为 FALSE。 

【实例 9-6】 利 用 mysqli_fetch_row0 函 数 显示 student 表 中 的 所 有 记录 。 


<?php 
include_once ("connect_mysql.php") > 
header ("Content-Type:text/html;charset=gb2312"); 
$sql="select * from student"; 
$result=mysqli query ($conn, $sql); 
while ($s=mysqli_fetch row ($result)) 
eeho S50] ww my // 显 示 字段 zh 的 值 
echo $5[1]. " "; ”// 显 示 字 段 xm 的 值 
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echo $92] YX // 显 示 字 段 bj 的 值 
echo $35[3]. ™ ™? // 显 示 字 段 cj 的 值 
echo “<br/>™; // 输 出 换行 符 

} 


程序 的 运行 结果 如 图 9-1 所 示 。 


1362163106 李 佳 程 机 械 2013-1 81 
1362163107 和 董 宇 杰 机 械 2013-1 96 





9-1 实例 9-6 的 运行 结果 
2. mysqli_fetch_array() 函 数 
函数 的 语法 格式 如 下 : 
array mysqli fetch array (result, result type) 
函数 的 参数 说 明 如 表 9-6 所 示 。 
表 9-6 mysqli_fetch_array() 函 数 的 参数 说 明 


参 数 说 明 
result 由 _mysqli_query0 返 回 的 结果 集 标识 符 
可 选 。 规 定 产生 数组 的 类 型 ， 可 以 是 以 下 值 中 的 一 个 。 
MYSQLI_ASSOC: 数组 索引 形式 ; 
result type 


MYSQLI_NUM: 数字 索引 数组 形式 ; 
MYSQLI_BOTH: 以 上 二 者 都 可 以 





函数 功能 : 该 函数 是 mysqli_fetch_row0 的 扩张 版 本 ， 函 数 的 返回 值 除 了 包含 
mysqli_fetch_row0 函 数 的 返回 值 外 ， 还 包含 select 语句 中 “字段 列表 => 字 段 列 表 值 ”的 数 
组 元 素 。 

【实例 9-7】 利 用 mysqli_fetch_array0 函 数 显 示 student 表 中 的 记录 。 


<?php 
include_once ("connect mysql .php"); 
header ("Content-Type:text/html;charset=gb2312"); 
$sql="select * from student"; 
$result=mysqli query ($link, $sql); 
while($s=mysqli fetch array ($result)) 
{ 





echo S39"sh je "ms // 显 示 字 段 xh 的 值 
echo SS["zm as ”5 // 显 示 字 段 xm 的 值 
ET // 显 示 字 段 bj 的 值 
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el // 显 示 字 段 cj 的 值 
echo "<br/>"7 
} 
人 过: 
3. mysqli_fetch_object() 函 数 
函数 的 语法 格式 如 下 : 
array mysqli fetch object (result, classname,params) 
函数 的 参数 说 明 如 表 9-7 所 示 。 
表 9-7 mysqli_fetch_object() 函 数 的 参数 说 明 





参 数 说 明 
result 由 mysqli_query0 返 回 的 结果 集 标识 符 
classname 可 选 。 规 定 要 实例 化 的 类 名 称 ， 设 置 属性 并 返回 
Pparams 可 选 。 规 定 一 个 传 给 classname 对 象 构造 器 的 参数 数组 
函数 功能 : 该 函数 从 结果 集中 取得 一 行 数据 ， 并 作为 对 象 返 回 。 若 结果 集 result 中 没 
有 记录 ， 则 函数 的 返回 值 为 FALSE。 
【实例 9-8】 利 用 mysqli_fetch_objectO 函 数 显示 student 表 中 的 记录 。 
<?php 
include_ once ("connect mysql.php"); 
header ("Content-Type:text/html;charset=gb2312"); 
$sql="select * from student"; 
$result=mysqli_query ($conn, $sql); 


while($s=mysqli_fetch object ($result)) 
{ 























// 显 示 字段 xh 的 值 
// 显 示 字段 xm 的 值 
// 显 示 字段 pj 的 值 
// 显 示 字 段 cj 的 值 


echo $s->xh. 
echo $s->xm. 
echo $s->bj. 
echo $s->cj. 
echo "<br/>"; 


} 
? > 


9.1.5 ”关闭 与 MySQL 数据 库 的 连接 


由 于 Web 系统 中 的 PHP 程序 需要 经 常 和 MySQL 服务 器 进行 交互 ， 而 数据 库 的 连接 
又 是 非常 宝贵 的 系统 资源 ， 当 用 户 与 MySQL 服务 器 的 连接 超过 一 定数 量 时 ， 会 导致 系统 
性 能 的 下 降 ， 甚 至 死机 。 因 此 操作 MySQL 数据 库 完 毕 ， 最 好 立即 关闭 与 MySQL 服务 器 
的 连接 。 常 用 的 函数 有 mysqli_free_result0 和 mysqli_close()。 

1. mysqli free_result() 函 数 

语法 格式 如 下 : 


.60\， 
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mysqli free result (result) 
函数 的 参数 说 明 如 表 9-8 所 示 。 
表 9-8 mysqli_close() 函 数 的 参数 说 明 


参 数 说 明 





result 由 mysqli_ query0 返 回 的 结果 集 标识 符 





函数 功能 : 释放 结果 集 所 占用 的 内 存 ， 该 函数 无 返回 值 。 
2. mysqli_close() 函 数 
语法 格式 如 下 : 
mysqli_close (connection) 
函数 的 参数 说 明 如 表 9-9 所 示 。 
表 9-9 mysqli_close() 函 数 的 参数 说 明 








参 数 说 明 
connection 要 关闭 的 MySQL 连接 
函数 的 功能 : 关闭 与 MySQL 服务 器 的 连接 。 
函数 的 返回 值 : 如 果 关 闭 成 功 返 回 TRUE， 和 否则 将 返回 FALSE。 


9.2 ”综合 实 训 案例 


本 节 主 要 介绍 在 PHP 程序 中 实现 分 页 显示 数据 的 方法 。 在 PHP 程序 中 ， 如 果 需 要 显 
示 的 记录 很 多 ， 而 在 一 个 页 面 上 无 法 显示 全 部 记录 ， 这 时 就 需要 分 页 显示 ， 即 将 记录 分 页 
来 显示 。 

分 页 是 一 种 将 信息 分 段 展示 给 浏览 器 用 户 的 技术 。 浏 览 器 用 户 每 次 看 到 的 不 是 全 部 信 
息 ， 只 是 其 中 的 一 部 分 信息 ， 用 户 可 以 指定 页 码 或 翻 页 的 方式 来 找到 自己 想 要 的 内 容 。 

1. 分 析 


创建 数据 库 student， 字 符 集 采用 utf8_unicode_ci; 创建 表 student_info， 表 结构 如 表 9-10 
所 示 。 





表 9-10 student_info 表 的 结构 








字 段 类 型 、 长 度 含 义 
xh varchar(12 学 号 
xm varchar(20) 姓名 
bj Varchar(20 班级 


为 了 准确 地 将 数据 表 记 录 分 页 显示 ， 需 要 计算 以 下 数据 。 
(fen. 
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@ 要 显示 的 记录 总 数 ($rec_count): 可 以 使 用 以 下 SQL 语句 获得 。 


$query="select * from student info order by xh "7 
S$get = mysqli query ($conn, $query); 
S$rec count=mysqli num rows ($get); 


@ 每 页 显示 的 记录 的 数量 ($page_size): $page_siae=10。 


人 
钼 眶 


页 码 ($pages)。 





@@ 
得 


起 始 记录 则 为 


$offset+$page size; 


前 页 码 ($this_page_no) :Sthis page_no=l 表示 第 一 页 。 


$pages=ceil ($rec_count/$page_size); 


当前 页 要 显示 的 起 始 记 录 所 在 行 ($offset): $offset=0 表示 第 一 条 记录 ， 下 





页 的 


在 MySQL 数据 库 服务 器 端 首先 计算 定位 当前 页 的 起 始 记 录 所 在 的 行 Soffset， 再 依次 
读 取出 该 页 显示 的 Spage_size 条 记录 并 返回 到 浏览 器 页 面 上 。 在 这 里 分 页 需要 使 用 MySQL 


的 谓词 limit， 其 语法 格式 如 下 : 


Limit [start,] length 


其 中 ，start 的 值 等 于 $offset，length 的 值 等 于 $page_size。 


2. 实现 过 程 


打开 浏览 器 ， 在 地 址 栏 中 输入 http://localhost/query.php?offset=0， 程 序 运行 结果 如 图 9-2 


所 示 。 


116114212 
116310422 
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116413410 
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3. 编程 实现 


(1) 创建 MySQL 连接 程序 ， 命 名 为 connect_mysql.php。 程 序 代码 如 下 : 


<?php 
global $conn; 
$host="localhost"; 
$user="root™; 
$password=""; 
$dbname="student"; 


.{ 162\. 
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图 9-2 分 页 显示 效果 


// 定 义 数 据 库 连接 标识 符 
//MySQL 服务 器 地 址 
//MySQL 登录 用 户 名 
//MySQL 登录 密码 

// 所 操作 的 数据 库 
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$conn=mysqli_connect ($host, $user, Spassword, $dbname); 
mysqli query ($conn,"set names gb2312"); 
2 


(2) 创建 query.php 程序 ， 用 来 分 页 显示 student 表 的 记录 。 程 序 代 码 如 下 : 


<?php 
include once ("connect mysql.php"); 
header ("Content-Type:text/html;charset=gb2312"); 
$offset=$_REQUEST['offset'];  // 记 录 的 偏 移 量 





if (empty ($0offset)) 
Soffset=07 // 第 一 页 的 起 始 记录 的 偏 移 量 
$this page_no=1; // 当 前 页 为 第 一 页 
$pages=1; 
. 
$page_size=10; // 每 页 显示 记录 的 数量 
?> 
<html> 
<head> 





Content-Language" content="zh-cn"> 
<meta http-equiv="Content-Type" content="text/html; charset=gb2312"> 
<title> 浏 览 学 生 名 单 </title> 
</head> 
<body style="font-family: ' 微 软 雅 黑 '"> 
<table width="100%" border="]1l" cellpadding="0" cellspacing="0" 
height="21" bordercolor="#CCCCCC" style="border-collapse: collapse"> <tr 
bgcolor="#FFFFFF"> 
<td width="30%" ><p align="center"> 学 号 </td> 
<td width="30%" ><p align="center"> 姓 名 </td> 
<td width="40%"><p align="center"> 班 级 </td> 
</Er> 
<?php 
$query="select * from student info order by xh"; 
$get = mysqli_query ($conn, $query); 
// 统 计 要 显示 的 记录 总 数 
$rec_count=mysqli_num rows ($get); 
// 分 页 显示 符合 要 求 的 记录 
$sqll= " select * from student info order by xh LIMIT 
S$offset, $page_size"; 
$get = mysqli_ query ($conn, $sql1); 
while( $r=mysqli fetch object ($get)) 
下 
echo "<tr><td height=24 width=30% >$r->xh</td>"; 
echo "<td height=24 width=30%>$r->xm</td>"; 
echo "<td height=24 width=40%>$r->bj</td>"; 
} 
echo "</tr>"; 
cx 
</table> 
<form method=post action="<? $_SERVER['PHP_SELF'];?>"?> 
<table width="100%" border="1l" cellpadding="0" cellspacing="1" bgcolor= 
"#FFFFFF" style="border-collapse: collapse" bordercolor="#EEEEEE"> 
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<tr> 
<td width =15% > 记录 数 : <?php echo S$rec count;?></td> 
<td width="85%" bgcolor="#FFFFFF"> 
<a href="<?php echo $_ SERVER['PHP SELF'];?>?0ffset=0" target= self> 
【首页 】</a>gnbsp; gnbsp; 
<?php 
if ($offset) // 如 果 偏 移 量 是 0， 不 显示 前 一 页 的 链接 
{ 
S$preoffset=$offset-$page size; 
echo "<a href="'$_ SERVERI[PHP_SELF] ?offset=$preoffset" 
target='_self'> 【上 一 页 】 </a>gnbsp; gnbsp;"; 


} 
// 计 算 总 共 需 要 的 页 数 
$pages=ceil ($rec count/$page size); 
// 检 查 是 否 是 最 后 一 页 
$nextoffset=$offset+$page_size; 
if (($pages!=0) && ($nextoffset<$rec_ count)) 
echo "<a href='$_SERVERI[PHP_SELF] ?offset=$nextoffset' 
target='_self'> 【下 一 页 】 </a>&nbsp; gnbsp;"; 
$last_offset=($pages-1)*$page_size; 
$this page_no=ceil ($offset/$page_size)+1; 
D> 
<a href="<?php echo $_SERVER['PHP_SELF'];?>?0ffset=<?php echo 
$last_offset;?>" target= self>【 尾 页 】</a> gnbsp; gnbsp; 
页 次 : <font color="red"> <?php echo S$this_page no;?> 
</font>/ 
<?php 
echo $pages; 
人 
页 </td> 
<WEr 
</table> 
</form> 
</body> 
</html> 


本 章 小 结 


本 章 详细 介绍 了 PHP 程序 中 连接 MySQL 服务 器 的 相关 函数 及 方法 ，PHP 程序 中 通过 
SQL 语句 操作 数据 表 记 录 的 方法 ， 以 及 遍历 MySQL 数据 表 记 录 的 方法 。 


习 题 


1. 编写 程序 ， 连 接 MySQL 服务 器 的 数据 库 bookmanage。 

2. 编写 程序 ， 向 student 表 插入 数据 : 学 号 为 1362163122， 姓 名 为 “ 刘 铁 铮 ”， 班 级 
为 “机 械 2013-1”， 成 绩 为 78。 

3. 编写 程序 ， 将 student 表 中 姓名 为 “ 朱 硕 ”的 成 绩 改 为 98。 

4. 编写 程序 ， 将 student 表 中 成 绩 大 于 70 的 记录 全 部 显示 出 来 。 
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本 章 要 点 

@@ ”Cookie 的 设置 与 应 用 

@ ”Session 的 设置 与 应 用 

学 习 目 标 

@ 掌握 Cookie 的 应 用 方法 

@ 掌握 Session 的 应 用 方法 

Cookie 和 Session 是 目前 使 用 的 两 种 信息 存储 机 制 。Cookie 是 从 一 个 Web 页 面 到 下 一 
个 页 面 的 数据 传递 方法 ， 存 储 在 客户 端 ; Session 是 让 数据 在 页 面 上 持续 有 效 的 方法 ， 存 储 
在 服务 器 上 。 

















10.1 ”Cookie 会 话 技术 


Cookie 是 某 些 网 站 为 了 辨别 用 户 身 份 、 进 行 Session 跟踪 而 储存 在 用 户 本 地 终端 上 的 
一 段 加 密 数据 。 

服务 器 可 以 利用 Cookies 包含 的 信息 来 判断 用 户 信 息 在 HTTP 传输 中 的 状态 。Cookies 
最 典型 的 应 用 是 判定 注册 用 户 是 否 已 经 登录 网 站 ， 用 户 可 能 会 得 到 提示 ， 是 否 在 下 一 次 进 
入 此 网 站 时 保留 用 户 信息 以 便 简 化 登录 手续 ， 这 些 都 是 Cookies 的 功用 。 


10.1.1 在 浏览 器 中 设置 Cookie 

















浏览 器 中 均 配 备 了 Cookie 的 设置 选项 ， 用 户 可 以 根据 需要 来 设置 是 否 开启 Cookie。 
下 浏览 器 设置 Cookie 的 方法 如 下 。 

启动 正 浏览 器 ， 单 击 菜单 项 “工具 ”， 在 其 下 拉 菜 单项 中 选择 “Interet 选项 ”， 在 
弹出 的 窗口 中 ， 选 择 “ 隐 私 ” 选 项 卡 ， 通 过 拖 动 “设置 ”区 域 的 滚动 块 来 设置 正 浏览 器 
中 的 Cookie 配置 。 一 般 情 况 下 ， 用 户 将 滚动 块 拖 至 “中 ”或 “中 高 ”就 可 以 既 保护 隐私 又 
开启 了 Cookie， 如 图 10-1 所 示 。 
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10.1.2 ”Cookie 的 功能 


Cookie 主要 有 以 下 3 个 方面 的 功能 : 
@ ”记录 访客 的 某 些 信息 。 例 如 ， 利 用 Cookie 记录 用 户 访问 





or rr NR 


网 页 的 次 数 ， 或 者 记录 访 


客 曾经 输入 过 的 信息 ， 还 可 以 记录 访客 上 次 登录 的 用 户 名 。 
@ ”在 页 面 之 间 传递 变量 。 浏 览 器 不 会 保存 当前 页 面 上 的 任何 变量 信息 ， 当 页 面 被 关 
闭 后 ， 页 面 上 变量 的 值 也 随 之 消失 。 但 是 可 以 通过 Cookie 将 变量 的 值 保存 下 来 ， 

















在 下 一 个 页 面 可 通过 读 取 Cookie 来 获取 该 变量 的 值 。 
@ ”将 所 查看 的 Intemet 页 面 存储 在 Cookie 临时 文件 夹 下 ， 
速度 。 


10.1.3 ”Cookie 的 分 类 


这 样 可 以 提高 以 后 的 浏览 


按照 Cookie 存在 的 时 间 ，Cookie 可 分 为 “会 话 Cookie”( 或 称 “ 非 持久 Cookie”) 和 


“持久 Cookie”。 
(1) 会 话 Cookie。 


若 创 建 Cookie 时 没有 指定 Cookie 的 过 期 时 间或 设置 的 Cookie 过 期 时 间 为 过 去 的 某 个 














寸 ， 会 在 内 存 中 删除 此 Cookie。 
(2) 持久 Cookie。 


对 间 ( 小 于 当前 的 UNIX 时 间 戳 )， 则 该 Cookie 是 一 个 会 话 Cookie。 当 退出 或 关闭 浏览 器 


若 创建 Cookie 时 指定 了 Cookie 的 过 期 时 间 为 将 来 的 某 个 时 间 (大 于 当前 的 UNIX 时 间 


戳 )， 并 且 浏 览 器 开启 了 Cookie 设置 ， 则 该 Cookie 是 一 个 持久 
信息 保存 在 浏览 器 端的 磁盘 文件 中 ， 该 信息 文件 会 长 期 有 效 ， 除 
失效 。 

@ 当前 的 UNIX 时间 惟 等 于 Cookie 的 过 期 时 间 。 

@， 用户 手动 删除 了 该 持久 Cookie。 

@ 浏览 器 中 的 Cookie 过 多 ， 超 过 了 浏览 器 所 允许 的 范 目 


Cookie。 持 久 Cookie 的 
非 出 现下 列 三 种 情况 才 会 





Cookie。 


10.1.4 创建 Cookie 


目 ， 浏 览 器 自动 删除 某 些 


在 PHP 程序 中 创建 Cookie， 可 以 使 用 函数 setcookie0 来 实现 ， 其 语法 格式 如 下 : 


bool setcookie (string name, string value,int expire,string path, string 


domain, int secure) 


函数 功能 :创建 Cookie， 若 创建 成 功 ， 该 函数 返回 TRUE， 否 则 返回 FALSE。 函 数 的 


参数 说 明 如 表 10-1 所 示 。 
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表 10-1 setcookie() 函 数 参 数 说 明 














参 数 说 明 
name 规定 Cookie 的 名 称 
value 规定 Cookie 的 值 
expire 可 选 。 规 定 Cookie 的 有 效 时 间 
path 可 选 。 规 定 Cookie 的 服务 器 路 径 
domain 可 选 。 规 定 Cookie 的 域名 





secure 可 选 。 规 定 是 否 通过 安全 的 HTTPS 连接 来 输出 Cookie 


【实例 10-1】 在 PHP 程序 中 创建 Cookie。 
创建 PHP 程序 文件 create_cookie php， 程 序 代 码 如 下 : 
<?php 
// 创 建 会 话 Cookie :cookiel 
Setcookie ("cookiel", "My _cookiel"); 
// 创 建 持久 Cookie: cookie2, 有 效 时 间 60 秒 
setcookie ("cookie2","MyY_cookie2",time ()+60) 7 
> 


[名 提示 :  。 Create_cookie.php 程序 中 没有 为 cookiel 指定 过 期 时 间 ， 所 以 cookiel 是 
一 个 会 话 Cookie， 会 话 Cookie 没有 保存 到 磁盘 文件 中 ， 当 浏览 器 关闭 
后 ，cookiel 立刻 失效 。 
@ cookie2 由 于 设 定 了 过 期 时 间 为 60 秒 ， 所 以 cookie2 是 一 个 持久 Cookie。 
Cookie 信息 保存 在 浏览 器 端的 C:\Documents and Settings\Administrator\Cookies 
文件 夹 下 的 一 个 文本 文件 中 ,文件 内 容 如 图 10-2 所 示 。 


CT 可 


事 
文件 四， 编辑 下 ) 格式 9) 查看 W 帮助 00 
cookie2My_cookie2localhost/1536119295488304908973820909643 三 
30490896* 







到 
图 10-2 ”Cookie 文件 信息 


10.1.5 ” 读 取 Cookie 








在 PHP 程序 中 通过 全 局 数组 $ COOKIE[] 来 读 取 浏览 器 端的 Cookie 值 。 
【实例 10-2】 读 取 Cookie。 
创建 PHP 程序 文件 show_cookie.php， 程 序 代码 如 下 : 


<?php 
header ("Content-Type:text/html;charset=gb2312"); 
if(isset($ COOKIE["cookiel"])) 
echo "会 话 Cookie: ".$_COOKIE["cookiel"] ."<br/>"; 
if(isset($ COOKIE["cookie2"])) 
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echo "持久 cookie: ".$_COOKIE["cookie2"]; 
2> 
打开 浏览 器 ， 先 执行 程序 create_cookie.php， 然 后 再 执行 程序 show_cookie.php， 则 程 
序 的 运行 结果 如 图 10-3 所 示 。 





园 localhost/ahor_cockis ; x WW 
所 © |D localhost/show_cookie. php 





会 话 Cookie: ly_cookiel 
持久 Cookie: Jy_cookie2 





10-3 ”创建 Cookie 运行 结果 


在 上 面 的 代码 中 ， 首 先 使 用 函数 isset0 来 判断 所 设置 的 Cookie 是 否 存 在 ， 若 存在 ， 则 
输出 Cookie 的 值 。 


10.1.6 删除 Cookie 


当 用 户 不 需要 Cookie 时 ， 可 以 删除 Cookie。 删 除 Cookie 的 方法 主要 有 以 下 两 种 。 
(二 方法 二 < 

使 用 函数 setcookie0 删 除 Cookie。 

@ ”使 用 函数 setcookie() 可 以 将 Cookie 的 值 设置 为 空 。 程 序 代 码 可 以 写 为 : 


<?php 
setcookie ("cookie2 ",""); 





> 
@ ”使 用 函数 setcookie0) 将 Cookie 的 有 效 时 间 设置 为 过 去 的 某 个 时 间 。 程 序 代码 可 以 
写 为 : 
<?php 
setcookie ("cookie2","My Cookie2",time()-3600); 
3 
(2 方法 三 。 


使 用 浏览 器 手动 删除 Cookie。 

选择 浏览 器 的 “工具 ”|“Intemet 选项 ”命令 ， 如 图 10-4 所 示 。 在 “常规 ”选项 卡 中 
单 击 “ 删 除 ”按钮 ， 会 弹出 “删除 浏览 历史 记录 ”对 话 框 。 选 择 “Cookie 和 网 站 数据 ” 选 
项 ， 再 单 击 “ 删 除 ”按钮 ， 即 可 删除 全 部 Cookie 文件 ， 如 图 10-5 所 示 。 
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10.2 ”Session 会 话 技术 
10.2.1 了 解 Session 


Session 是 指 一 个 终端 用 户 与 交互 系统 进行 通信 的 时 间 间 隔 ， 通 常 是 指 注 册 进 入 系统 到 
注销 退出 系统 之 间 所 经 过 的 时 间 。 

从 用 户 使 用 浏览 器 第 一 次 访问 服务 器 到 断 开 与 服务 器 的 连接 为 止 ， 系 统 会 生成 一 
Session 会 话 生 命 周期 ， 在 此 周期 内 ， 服 务 器 会 为 每 一 个 浏览 器 用 户 分 配 一 个 唯一 的 
Session ID 来 标识 当前 的 用 户 。Session ID 是 一 个 加 密 的 随机 字符 串 ， 能 够 确保 其 唯一 性 和 
随机 性 ，Session 信息 保存 在 服务 器 端 ， 确 保 Session 信息 的 安全 性 。 


10.2.2 ”Session 与 Cookie 的 区 别 


Session 文件 用 来 存储 每 个 浏览 器 用 户 的 信息 ， 而 且 Session 文件 保存 在 服务 器 端 。 为 
了 避免 对 服务 器 造成 过 大 的 负荷 ，Session 也 存在 着 有 效 期 的 概念 。 同 Cookie 类 似 ， 当 
Session 的 有 效 期 过 后 ，Session 也 会 自动 失效 。Session 与 Cookie 有 以 下 几 点 区 别 : 
@ Scan 的 信息 保存 在 服务 器 端 ，Cookie 的 信息 保存 在 浏览 器 用 户 端 。 
@ ”浏览 器 用 户 可 以 禁用 浏览 器 的 Cookie， 但 是 无 法 停止 服务 器 端 Session 的 使 用 。 
@ ”用户 关闭 浏览 器 只 会 使 浏览 器 端的 Cookie 失效 ， 不 会 使 服务 器 端的 Session 失 
效 。 用 户 每 次 通过 浏览 器 登录 网 站 时 ， 服 务 器 都 会 生成 一 个 新 的 Session ID 和 
Session 文件 来 使 用 。 
@ ”Session 存储 的 数据 可 以 是 复合 数据 类 型 ， 例 如 数组 或 对 象 ，Cookie 存储 字符 串 
数据 。 
@ 在 使 用 Session 第 一 次 访问 Web 页 面 时 ， 服 务 器 端 会 产生 Session 的 信息 ， 因 此 
Web 页 面 可 以 直接 访问 该 Session 的 信息 ; 而 Cookie 在 第 一 次 访问 Web 页 面 
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时 ， 只 有 Web 页 面 响应 后 才 生 成 Cookie 信息 ， 所 以 第 一 次 访问 页 面 不 会 访问 到 
Cookie 信息 。 


10.2.3 ”Session 的 设置 
1. 在 php.ini 中 设置 
在 php.ini 文件 中 有 一 些 Session 的 相关 配置 ， 具 体 含义 如 表 10-2 所 示 。 
表 10-2 php.ini 中 Session 的 配置 选项 


配 置 含义 
设置 服务 器 端 Session 信息 的 保存 方式 。files 表示 用 文件 存储 


Session 信息 





session.save_handle=files 


session.save_path="C:\xampp\tmp"” | 设置 Session 文件 保存 的 路 径 
session.use_cookies=1 1 表示 Session ID 使 用 Cookie 传递 ，0 表示 使 用 查询 字符 串 传递 
session.name=PHPSESSID Session ID 的 名 称 
设置 浏览 器 请 求 服务 器 页 面 时 ， 是 否 自动 开启 Session。 默 认为 
0， 表 示 不 自动 开启 Session 
设置 Session ID 在 Cookie 中 的 过 期 时 间 。 默 认为 0， 表示 浏览 器 
一 旦 关闭 ，Session ID 立即 失效 
设置 使 用 Cookie 传递 Session ID 时 ，Cookie 的 有 效 路 径 ， 默 认 
为 / 
设置 使 用 Cookie 传递 Session ID 时 ，Cookie 的 有 效 域名 ， 默 认 
为 空 
设置 Session 文件 在 服务 器 端的 存储 时 间 ， 单 位 为 秒 。 若 超过 这 
个 时 间 ， 则 Seesion 文件 自动 被 删除 


session.auto_start=0 
session.cookie_lifetime=0 
session.cookie_path=/ 
session.cookie_domain= 


session.gc_maxlifetime=1440 


2. 预定 义 系统 变量 $_SESSION 


$_SESSION 和 $_COOKIE 一 样 ， 都 是 全 局 数组 ，$_SESSION 的 功能 如 下 : 

@ 使 用 $_SESSION 数组 的 赋值 语句 添加 或 修改 数组 元 素 ， 服 务 器 以 “ 键 名 | 值 类 型 : 
长 度 : 值 ” 的 格式 序列 化 到 Session 对 应 的 Session 文件 中 。 

@ ”可 以 使 用 $_SESSION 数组 读 取 Session 文件 中 的 信息 。 

@ ”可 以 使 用 unset0 函 数 释放 内 存 中 $_SESSION 数组 的 某 些 元 素 ， 此 时 Session 文件 
中 的 对 应 信息 也 将 被 删除 ， 但 该 函数 无 法 删除 Session 文件 。 


10.2.4 ， Session 的 启动 和 删除 





1. Session 的 启动 
在 PHP 程序 中 要 想 启动 Session， 必 须 调 用 session_start(0) 函 数 ， 其 语法 格式 如 下 : 
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bool session start() 
该 函数 没有 参数 ， 返 回 值 永远 为 TRUE。 
函数 功能 : 
@ 加 载 phpini 文件 中 有 关 Session 的 配置 信息 到 Web 服务 器 内 存 中 。 
@ 创建 Session ID 或 使 用 已 有 的 Session ID 。 
@ 在 Web 服务 器 中 创建 Session 或 者 解析 已 有 的 Session 文件 。 
@ 产生 Cookie 响应 头 信息 ，Cookie 响应 头 信息 会 随 着 响应 发 送 给 浏览 器 。 
2. Session 的 删除 


如 果 想 要 在 PHP 程序 中 删除 Session 信息 ， 可 以 使 用 PHP 提供 的 unset0) 函 数 、 
session_unset() 函 数 和 session _destroy() 函 数 。 
(1) unset0 函 数 的 语法 格式 。 
void unset (mixed varl,var2,..,varn) 
函数 功能 : 释放 给 定 的 变量 。 
【实例 10-3】 利 用 unset0 函 数 删除 Session 信息 。 


<?php 
session_start (); // 启 动 Session 
header ("Content-Type:text/html;charset=gb2312"); 
$user="root"; 
S$pwd="abc123"7 
$_SESSION["user name"]="root"; 
$_SESSION ["password"]="abc123"7 
unset ($_SESSION["password"]) 7 





2> 
号 提示 : 利用 unset0 通 数 可 以 删除 指定 的 Session 信息 。 
(2) session_unset0 函 数 的 语法 格式 。 


void session unset() 


函数 功能 : 删除 当前 内 存 中 $_SESSION 数组 中 的 所 有 元 素 ， 并 删除 Session 文件 中 的 
用 户 信息 ， 但 并 不 删除 Session 文件 以 及 不 释放 对 应 的 Session ID 。session_unsetO 函 数 等 价 
于 程序 命令 “$_SESSION=array0:”。 

(3) session_destroy() 函 数 的 语法 格式 。 


bool session destroy() 


函数 功能 : 销毁 Session 文件 ， 并 将 Session ID 置 为 0， 销毁 成 功 后 函数 返回 TRUE， 
否则 返回 FALSE。 

【实例 10-4】Session 应 用 。 

创建 以 下 PHP 程序 文件 ， 程 序 文件 及 用 途 如 表 10-3 所 示 。 
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表 10-3 ”Session 程序 文件 及 用 途 











程序 文件 用 途 
create_session.php 创建 Session 及 其 对 应 的 值 
show_session.php 显示 所 创建 Session 的 值 
update_session.php 修改 Session 的 值 
delete_session.php 删除 Session 中 的 一 个 信息 





delete_all_session.php 删除 全 部 的 Session 





create_session.php 代码 如 下 : 


<?php 
session_start (); // 启 动 Session 
header ("Content-Type:text/html;charset=gb2312"); 
$_SESSION["user name"]="root"; 
$_SESSION["password"]="abcl23"; 
echo "已 创建 Session!"; 

es 


程序 运行 如 图 10-6 所 示 。 


已 创建 Session! 





图 10-6 创建 Session 运行 结果 


show_session .php 代码 如 下 : 


<?php 
session_start (); 
$user_ name=$_SESSION["user name"]; 
$password=$_SESSION["password"]; 
echo "user name: ". $user name. "<br/>"; 
echo "password: ".$password; 

2 


程序 运行 结果 如 图 10-7 所 示 。 


© BD localhost/s 


user_nare: root 


password: abcl23 





10-7 显示 所 创建 的 Session 
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update_session.php 代码 如 下 : 


<?php 
session start(); 
header ("Content-Type:text/html;charset=gb2312"); 
$_SESSION["user name"]="new user"; 
$_SESSION["password"]="new_password"; 
echo "修改 后 的 Session:". "<br/>"; 
echo $_SESSION["user name"]. "<br/>"; 
echo $_SESSION["password"]; 
?> 


程序 运行 结果 如 图 10-8 所 示 。 


园 :ccalhost/update_sesss- X 


< @ 口 localhost/upd 
修改 后 的 Session: 


new_user 
new_password 





10-8 修改 后 的 Session 


delete_session .php 代码 如 下 : 


<?php 
session_start (); 
header ("Content-Type:text/html;charset=gb2312"); 
unset ($_SESSION["user name"]); 
echo "删除 Session 中 的 user_name 信息 "; 
?> 


程序 运行 结果 如 图 10-9 所 示 。 


国 1ocalhost/delete ses:; 


所 CC DD localhost/d 


删除 Session 中 的 user_name 信 息 





10-9 删除 Session 中 的 user_name 


delete_all_session.php 代码 如 下 : 


<?php 
session_ start (); 
session destroy(); 
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header ("Content-Type:text/html;charset=gb2312"); 
echo "Session 已 全 部 被 销毁 ! "; 


2 


程序 运行 结果 如 图 10-10 所 示 。 


€ 3 CC |B localhost/delete all_sessiorYy 
Session 已 全 部 被 销毁 ! 





图 10-10 ”删除 全 部 Session 信息 
10.3 ”综合 实 训 案例 


本 节 主 要 介绍 利用 Session 在 多 个 页 面 间 传递 用 户 登录 信息 的 方法 和 步 又 。 

1. 分 析 

用 户 登 录 网 站 时 ， 输 入 用 户 名 和 密码 ， 经 过 验证 后 ， 若 用 户 输 入 的 用 户 名 和 密码 是 有 
效 的 ， 则 将 用 户 的 登录 信息 写 入 Session， 然 后 进入 主页 面 。 

创建 login.html 页 面 ， 其 中 包含 一 个 form 表单 ， 内 含 两 个 文本 框 ， 文 本 框 属性 如 
表 10-4 所 示 。 


表 10-4 文本 框 属性 




















所 示 。 


欢迎 登录 


用 户 名 john 





图 10-11 login.html 页 面 启动 
创建 check loginphp， 打 开 user 表 ， 验 证 用 户 提交 的 用 户 名 和 密码 是 否 正确 ， 若 正 
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确 ， 则 将 提交 的 信息 写 入 Session， 并 进入 主页 面 ， 和 否则 返回 到 login.html。 


/TN. 


创建 main.php， 显 示 Session 信息 。 
2. 程序 代码 
login.html 代码 如 下 : 


<html> 

<head> 

<meta http-equiv="Content-Language" content="zh-cn"> 

<meta http-equiv="Content-Type" content="text/html; charset=gb2312"> 

<title> 登 录 页 面 </title> 

</head> 

<body> 

<form action ="check_login.php" method=post> 

<p align=center> 欢 迎 登录 </p> 

用 户 名 <input type="text" name="login name" ><br/> 

密码 <input type="password" name="login password"><br/> 
<input type="submit" value=" 提 交 " name="Bl">&nbsp;&nbsp; &nbsp; &nbsp; 
<input type="reset" value=" 重 置 " name="B2"><br/> 


</form> 

</body> 

</html> 

connect_mysql.php 程序 代码 如 下 : 

<?php 
global $conn; / /数据 库 连 接 标 识 符 
$host="localhost"; //MySQL 服务 器 地 址 
$username="root"; // 登 录 MySQL 服务 器 用 户 名 
$password=""; // 登 录 MySQL 服务 器 密码 
$database="e-shop"; // 要 操作 的 数据 库 


$conn=mysqli_connect ($host, $username, Spassword, $database); 
mysqli_query ($conn, "set names gb2312"); 
if (mysqli_connect errno ($conn)) 
die ("MySQL 服务 器 连接 失败 ! " .mysqli_connect_error()); 
?> 


check_login.php 程序 代码 如 下 : 


<?php 

session start (); 

include_once ("connect mysql .php"); 

$user=$_POST["login name"]; 

$pwd=$_POST["login password"]; 

$sql="select * from user Where user="'$user' and password="'$pwd'™"; 

$get=mysqli_query ($conn, $sql); 

$rows=mysqli_num rows ($get); 

if ($rows>0) 

i 
$_SESSION["login user"]=$user; // 将 登录 用 户 名 写 入 Session 
$_SESSION["login password"]=$pwd;  // 将 登录 密码 写 入 Session 
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header ("Location:main.php"); // 跳 转 入 main .php 
} 
else 
{ 
header ("Location:login.html"); 


za 


main.php 程序 代码 如 下 : 


<?php 
header ("Content-Type:text/html;charset=gb2312"); 
echo "登录 用 户 名 : "，,$_SESSION["login user"], "<br/>"; 


echo "登录 密码 : "，,$_SESSION["login password"], "<br/>"; 
?> 


本 章 小 结 


本 章 详细 介绍 了 PHP 中 Cookie 的 特点 和 分 类 ，Cookie 的 创建 、 读 取 和 删除 的 方法 和 
步骤 ， 以 及 Session 的 启动 和 删除 。 


习 题 


1. 创建 Cookie， 名 称 为 my_cookie， 有 效 时 间 为 2 分 钟 。 
2. 已 知 变量 $user name 的 值 为 john ，S$user password 的 值 为 abc123， 将 其 写 入 
Session 并 显示 Session 信息 。 


3. 已 知 变量 $name 的 值 为 Candy，S$type 的 值 为 admin， 将 其 写 入 Session， 然 后 删除 
type 的 Session 信息 。 
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本 章 要 点 

@ 了 解 GD2 函数 库 

@ 通过 GD2 绘制 各 种 图 形 

@ 绘制 文字 

学 习 目 标 

@ 掌握 在 GD2 下 各 种 图 形 的 绘制 
@ 掌握 在 GD2 下 文字 的 绘制 


11.1 GD 函数 库 
11.1.1 了 解 GD 函数 库 


利用 PHP 程序 不 仅 可 以 对 HTML 进行 输出 ， 还 可 以 创建 和 操作 各 种 不 同 格式 的 图 像 
文件 ， 设 置 输出 图 像 流 到 浏览 器 。 要 想 在 PHP 程序 中 实现 图 形 图 像 的 处 理 ， 就 要 在 编译 
PHP 程序 时 加 载 图 像 函 数 库 一 一 GD 库 。 

GD 函数 库 是 一 个 动态 创建 图 像 的 开源 的 函数 库 ， 可 以 从 官方 网 站 http://libgd.github.io/ 
下 载 最 新 版 的 GD 库 ， 目 前 GD 库 最 新 版 为 2.1.1， 所 以 GD 库 简称 为 GD2。 


11.1.2 设置 GD2 函数 库 


如 果 要 在 PHP 中 配置 GD2 属性 ， 需 要 打开 php.ini 文件 ， 找 到 选项 
“;extension=php_gd2.dll”， 将 之 前 的 分 号 删除 ， 如 图 11-1 所 示 。 重 新 启动 Apache 服务 器 
后 ， 就 可 以 使 用 GD2 函数 库 了 。 目 前 PHP 已 将 GD2 函数 库 作 为 默认 的 扩展 。 


短 php. ini - 记事 本 [=IS1x] 
文件 四 _ 蝙 辑 亿 ) 格式 中) 查看 如 帮助 如 


extension=php_gd2.dll 一 





图 11-1 phpjini 中 关于 GD2 的 设置 
加 载 GD2 成 功 后 ， 可 以 通过 phpinfo(0) 函 数 来 获取 GD2 函数 库 的 安装 信息 。 编 辑 PHP 
程序 文件 ， 写 入 代码 : 


<?php 
phpinfo(); 
2> 


该 程序 的 运行 结果 如 图 11-2 所 示 。 





.180 1， 


态 图 形 、 


11:2:4 


第 11 章 多 形 图 保 外 理 芭 2 






























































11-2 ”GD2 函数 库 安装 信息 


11.2 ”常见 图 像 处 理 


PHP 中 的 GD2 函数 库 用 于 创建 或 处 理 图像 ， 通 过 GD2 函数 库 可 以 生成 统计 图 表 、 动 


图 形 验证 码 等 。 在 PHP 程序 中 处 理 图 像 的 操作 主要 分 为 以 下 4 个 步骤 。 
创建 画布 。 

在 画布 上 绘制 图 形 。 

保存 并 输出 图 像 。 

销毁 图 像 资 源 。 


创建 画布 


在 PHP 程序 中 ， 无 论 创建 什么 样 的 图 像 都 要 先 创建 一 个 画布 ， 其 他 的 操作 都 是 在 画布 
上 完成 。 创 建 画 布 可 以 通过 函数 imagecreate() 和 函数 imagecreatecolor() 来 完成 ， 其 语法 格 


式 如 下 : 


resource imagecreate(int x size, int y_size) 

resource imagecreatetruecolor (int x size, int Y_size) 

函数 功能 :创建 一 个 指定 大 小 的 画布 。imagecreate() 函 数 创建 的 是 一 个 基于 普通 调 色 
板 的 图 像 ， 通 常 支持 256 色 。imagecreatecolor() 函 数 创建 的 是 一 个 真 彩色 的 画布 。 这 两 个 
函数 的 返回 值 为 一 个 图 像 标识 符 ， 以 后 可 以 通过 函数 imagesXO 和 imagesY() 来 获取 画布 的 
高 度 和 宽度 。 

函数 参数 说 明 如 表 11-1 所 示 。 














表 11-1 函数 imagecreate() 和 imagecreatetruecolor() 的 参数 说 明 


说 明 
图 像 横向 的 尺寸 ， 以 像素 为 单位 








图 像 纵 向 的 尺寸 ， 以 像素 为 单位 
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【实例 11-1】 通 过 函数 imagecreate0 创 建 画 布 。 


<?php 
header ("Content-Type:text/html;charset=gb2312"); 
$image=imagecreatetruecolor (500, 600); 
echo "画布 的 宽度 : ", imagesX ($image), "<br/>"; 
echo "画布 的 高 度 : ", imagesY (Simage) 
2> 


程序 运行 结果 如 图 11-3 所 示 。 


© BD localhost 


画布 的 宽度 ，500 
画布 的 高 度 ，600 





图 11-3 ”实例 11-1 运行 结果 
11.2.2 设置 颜色 


画布 创建 完成 后 ， 接 下 来 就 要 设置 图 像 的 颜色 。 颜 色 
imagecolorallocate() 来 完成 ， 其 语法 格式 如 下 : 


的 设置 可 以 通过 函数 


int imagecolorallocate (resource image, int red, int green, int blue) 


函数 功能 ， 为 画布 中 创建 的 图 像 填充 颜色 ,并且 为 画布 本 身 填充 颜色 。 


函数 参数 说 明 如 表 11-2 所 示 。 
表 11-2 函数 imagecolorallocate() 的 参数 说 明 








参 数 说 明 
image 图 像 的 标识 符 
Ted 红色 颜色 值 ， 取 值 0~255 
green 绿色 颜色 值 ， 取 值 0~255 
blue 蓝 色 颜色 值 ， 取 值 0~255 


【实例 11-2】 为 画布 填充 颜色 。 
<?php 
header ("Content-type:image/jpeg"); 
$image=imagecreate (300,100); 
$color=imagecolorallocate ($image, 160, 220,100); 
2> 


11.2.3 ”生成 图 像 


当 画 布 创建 完成 ， 颜 色 填充 后 ， 就 可 以 生成 图 像 和 输出 文字 了 





(ea. 


// 创建 画布 
// 为 画布 填充 颜色 


。 在 PHP 中 可 以 直接 生 
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成 的 图 像 格式 有 四 种 : GIF、JPEG、 PNG 和 WBMP。 如 果 生 成 的 图 像 要 输出 到 浏览 
上 ， 还 需要 在 PHP 程序 中 发 送 标 头 信息 来 设置 MIME 文件 类 型 ， 针 对 GIF、JPEG、PNG 
和 WBMP 这 四 种 图 像 分 别 使 用 的 标 头 信息 文件 信息 如 下 : 

@ content-type:image/gif 





® content-type:image/jpeg 
® content-type:image/png 


@ content-type:image/wbmp 
1.imagegif() 函 数 
以 GIF 格式 将 图 像 输出 到 浏览 器 上 ， 其 语法 格式 如 下 : 
bool imagegif (resource image, string filename) 
函数 的 参数 说 明 如 表 11-3 所 示 。 

表 11-3 函数 imagegif() 参 数 说 明 


规定 由 imagecreate0) 或 imagecreatetruecolor0 创 建 的 图 像 标识 符 
filename, 可 选 。 指 定 输出 图 像 的 文件 名 ， 若 忽略 ， 则 原始 图 像 流 将 被 直接 输出 





2. imagejpeg() 函 数 
以 JPEG 格式 将 图 像 输出 到 浏览 器 上 ， 其 语法 格式 如 下 : 
bool imagejpeg (resource image string filename,int quality) 
函数 的 参数 说 明 如 表 11-4 所 示 。 
表 11-4 函数 imagejpeg() 参 数 说 明 





参 数 说 明 
image 规定 由 imagecreate0) 或 imagecreatetruecolorO 创 建 的 图 像 标识 符 
filename 可 选 。 指 定 输出 图 像 的 文件 名 ， 若 忽略 ， 则 原始 图 像 流 将 被 直接 输出 
quality 可 选 。 规 定 图 像 质量 。 取 值 范围 从 0( 最 差 质 量 ， 文 件 最 小 ) 到 100( 最 佳 质量 ， 文 件 最 





大 )， 默 认为 75 

3.imagepng() 函 数 

以 PNG 格式 将 图 像 输出 到 浏览 器 上 ， 其 语法 格式 如 下 : 
bool imagepng (resource image, string filename) 
函数 的 参数 含义 与 imagegifO 函 数 的 参数 含义 相同 。 
4.imagewbmp() 函 数 

以 WBMP 格式 将 图 像 输出 到 浏览 器 上 ， 其 语法 格式 如 下 : 


(faa\. 
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bool imagewbmp (resource image,string filename,int foreground) 
函数 的 参数 说 明 如 表 11-5 所 示 。 
表 11-5 函数 imagewbmp() 的 参数 说 明 





参 数 说 明 
image | 规定 由 imagecreate0 或 imagecreatetruecolor0 创 建 的 图 像 标 识 符 





filename 可 选 。 指 定 输出 图 像 的 文件 名 ， 若 忽略 ， 则 原始 图 像 流 将 被 直接 输出 





可 选 。 规 定 前 景色 ， 默 认 前 景色 为 黑色 
【实例 11-3】 创 建 画 布 并 输出 。 


<?php 
header ("Content-type:image/jpeg"); 
$image=imagecreate (300,100); // 创建 画布 


$color=imagecolorallocate ($image,160,220,100); // 填 充 画 布 
imagejpeg ($image); 
> 


程序 运行 结果 如 图 11-4 所 示 。 





图 11-4 实例 11-3 运行 结果 


11.2.4 ”销毁 图 像 

PHP 程序 处 理 图 像 的 最 后 一 个 环节 就 是 销毁 图 像 。 所 谓 销毁 图 像 就 是 释放 内 存 与 指定 
图 像 的 存储 单元 ， 可 以 通过 imagedestroy0 函 数 来 完成 。 该 函数 的 语法 格式 如 下 : 

bool imagedestroy (resource image) 


函数 功能 : 释放 与 图 像 标识 image 关联 的 内 存 。 其 中 参数 image 是 由 图 像 创建 函数 返 











回 的 图 像 标识 符 。 
【实例 11-4】 创 建 画 布 并 输出 。 
<?php 
header ("Content-type:image/jpeg"); 
$image=imagecreate (300,100); // 创建 画布 
$color=imagecolorallocate ($image,160,220,100); // 填 充 画 布 
imagejpeg ($image); // 输 出 JPEG 图 像 


imagedestroy ($image); // 销 毁 图 像 资 源 
> 
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11.2.5 ”绘制 点 与 线 
在 PHP 程序 中 绘制 图 像 ， 首 先 要 明确 绘图 的 坐标 系 的 设置 。 坐 标的 原点 (0.0) 位 于 画布 
的 左上 角 ， 从 左 向 右 为 x 轴 的 正方 向 ， 从 上 向 下 为 y 轴 的 正方 向 ， 图 像 以 像素 为 单位 。 
1. 绘制 点 
在 PHP 程序 中 绘制 点 ， 可 以 通过 函数 imagesetpixel0 来 完成 。 该 函数 的 语法 格式 如 下 : 
bool imagesetpixel (int image,int x,int y,int color) 


函数 功能 : 在 image 图 像 上 用 颜色 color 在 坐标 (x,y) 上 绘制 一 个 点 。 
【实例 11-5】 在 画布 上 绘制 点 。 








<?php 
header ("Content-type:image/jpg"); 
$image=imagecreate (300,200); // 创建 画布 
$color=imagecolorallocate ($image, 215, 215, 215); // 画 布 的 填充 颜色 
$colorl=imagecolorallocate ($image, 0,0,0); // 点 的 颜色 
for ($i=10; $i<200; $i+=10) // 在 画布 上 绘制 点 
imagesetpixel ($image, $i+30, $i+20, $colorl1); 
imagejpeg ($image); // 输 出 JPEG 图 像 
imagedestroy ($image); // 销 毁 图 像 资源 
7 


程序 运行 结果 如 图 11-5 所 示 。 


国 ,=a=ple ll-5. php (300” x 几 
二 © DD localhost/e 





图 11-5 实例 11-5 运行 结果 
2. 绘制 线 
在 PHP 程序 中 绘制 直线 ， 可 以 通过 函数 imageline0 来 完成 。 该 函数 的 语法 格式 如 下 : 
bool imageline (int image,int xl,int yl,int x2,int y2,int color) 


函数 功能 : 在 image 图 像 上 用 颜色 color 从 坐标 (x1,y1) 到 (x2,y2) 上 绘制 一 条 直线 。 
【实例 11-6]】 在 画布 上 绘制 一 条 直线 。 
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<?php 
header ("Content-type:image/jpeg"); 
$image=imagecreate (300,200); // 创建 画布 
$color=imagecolorallocate ($image, 215, 215, 215); // 画 布 的 填充 颜色 
$colorl=imagecolorallocate ($image, 0,0,0); // 线 的 颜色 
imageline ($image, 20,20,150,150, $colorl1); 
imagejpeg ($image); // 输 出 JPEG 图 像 
imagedestroy ($image); // 销 毁 图 像 资源 
区 之 


程序 运行 结果 如 图 11-6 所 示 。 


example_11-6. php (300 


< © Dlocalhost/exanple_11- 





图 11-6 实例 11-6 运行 结果 
11.2.6 ”绘制 几何 图 形 
在 PHP 程序 中 ， 除 了 可 以 绘制 点 和 线 外 ， 还 可 以 绘制 其 他 几何 图 形 ， 如 和 矩形、 多 边 
形 、 弧 线 、 圆 和 椭圆 等 。 
1. 绘制 矩形 
绘制 矩形 可 以 通过 函数 imagerectangle() 来 完成 。 该 函数 的 语法 格式 如 下 : 
bool imagerectangle (resource image,int xl,int yl,int x2,int y2,int color) 


函数 功能 : 用 颜色 color 在 image 图 像 上 绘制 一 个 矩形 ， 和 矩形 的 左上 角 坐 标 为 (x1,y1)， 


右 下 角 坐 标 为 (x2.y2)。 
【实例 11.7】 在 画布 上 绘制 一 个 矩形 。 

<?php 
header ("Content-type:image/jpeg"); 
$im=imagecreate (300, 200); // 创 建 画布 
$color=imagecolorallocate ($im, 215, 215, 215); // 画 布 的 填充 颜色 
$colorl=imagecolorallocate ($im, 0,0,0); // 和 矩形 的 边框 线 颜 色 
imagerectangle ($im, 20, 20,150,150, $colorl1); 
imagejpeg ($im); // 输 出 JPEG 图 像 
imagedestroy ($image); // 销 毁 图 像 资源 

2 
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程序 运行 结果 如 图 11-7 所 示 。 


回 :=a=ple ll-7.php (300> x 
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图 11-7 实例 11-7 运行 结果 
2. 绘制 多 边 形 
多 边 形 的 绘制 可 以 通过 函数 imagepolygon() 来 完成 。 该 函数 的 语法 格式 如 下 : 
bool imagepolygon (resource image,array points,int num points,int color) 
函数 参数 说 明 如 表 11-6 所 示 。 
表 11-6 函数 imagepolygon() 参 数 说 明 


一 个 PHP 数组 ， 包 含 多 边 形 各 顶点 的 坐标 ， 即 point[0]=x0，points[1]=y0，point[2]=x2， 





规定 多 边 形 边线 的 颜色 
【实例 11-8】 在 画布 上 绘制 一 个 多 边 形 。 

<?php 
header ("Content-type:image/jpeg"); 
$im=imagecreate (300, 200); // 创建 画布 
$color=imagecolorallocate ($im, 215, 215, 215); // 面 布 的 填充 颜色 
$colorl=imagecolorallocate ($im, 0,0,0); // 多 边 形 边线 的 颜色 
imagepolygon ($im,array (20,20,175, 90,110,165,75,75),4,$colorl); 
imagejpeg ($im); // 输 出 JPEG 图 像 
imagedestroy ($im); // 销 毁 图 像 资源 

2 


程序 运行 结果 如 图 11-8 所 示 。 
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园 sxasple_11-s. php (300> x 
i 


CD localhost/exanple 





图 11-8 实例 11-8 运行 结果 
3. 绘制 弧 线 
在 PHP 程序 中 可 以 通过 函数 imagearc() 来 绘制 椭圆 弧 。 该 函数 的 语法 格式 如 下 : 
bool imagearc (resource image,int cx,int cy,int wint h,int s,int eint color) 
函数 参数 说 明 如 表 11-7 所 示 。 
表 11-7 函数 imagearc() 参 数 说 明 





参 数 说 明 
image 规定 由 imagecreate0 或 imagecreatetruecolorO 创 建 的 图 像 标 识 符 
Cx, Cy 椭圆 的 中 心 坐标 
WwW，h w: 椭圆 的 水 平 轴 长 ，h: 椭圆 的 垂直 轴 长 
S，e s: 椭圆 弧 的 起 始 角度 ，e: 椭圆 弧 的 结束 角度 
color 椭圆 弧 的 边线 颜色 
【实例 11-9】 在 画布 上 绘制 圆 、 椭 圆 及 椭圆 弧 。 
<?php 
header ("Content-type:image/jpeg"); 
$im=imagecreate (300,200); // 创建 画布 
$color=imagecolorallocate ($im, 215, 215, 215); // 画 布 的 填充 颜色 
$colorl=imagecolorallocate ($im, 10, 20,100); // 边 线 的 颜色 
imagearc ($im, 60,100,100, 100,0,360, $color1); // 画 圆 
imagearc ($im, 200,130,100, 70,0,360, $color1); // 画 椭圆 
imagearc ($im, 200, 80,100, 70, 180, 360, $color1); // 画 椭圆 弧 
imagejpeg ($im); // 输 出 JPEG 图 像 
imagedestroy ($im); // 销 毁 图 像 资 源 
2 


程序 运行 结果 如 图 11-9 所 示 。 
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图 11-9 实例 11-9 运行 结果 


4. 设置 线 的 宽度 

PHP 绘制 几何 图 形 时 ， 默 认 的 边线 宽度 为 1 像素 。 如 果 想 要 改变 边线 的 宽度 ， 可 以 通 
过 函数 imagesetthickness() 来 完成 。 函 数 的 语法 格式 如 下 : 

bool imagesetthickness (resource image, int thickness) 

函数 功能 : 设置 直线 、 和 矩形 、 多 边 形 等 图 像 的 边线 的 宽度 为 thickness 像素 。 如 果 成 
功 ， 则 返回 TRUE， 和 否则 返回 FALSE。 

在 实例 11-8 中 ， 如 要 设置 所 绘制 的 图 形 边线 的 宽度 为 5 像素， 可 以 在 设置 边线 颜色 的 
语句 之 后 添加 命令 : 


imagesetthickness ($im, 5); 


11.2.7 ”填充 几何 图 形 

在 PHP 程序 中 ， 有 时候 需要 对 图 形 进行 填充 ， 比 如 绘制 圆 饼 图 时 ， 就 需要 对 图 形 进行 
填充 。 

1. 区 域 填充 
区 域 填充 就 是 针对 图 形 中 的 某 个 区 域 进行 填充 。 区 域 填充 可 以 通过 imagefill0 函 数 或 
imagefill to border() 函 数 来 完成 。 

imagefill() 函 数 的 语法 格式 如 下 : 

bool imagefill (resource image,int x,int y,int color) 

函数 功能 : 从 坐标 点 (xy) 开 始 ， 用 颜色 color 将 与 x、y 相 邻 且 颜 色相 同 的 点 进行 填充 。 

函数 的 参数 说 明 如 表 11-8 所 示 。 

表 11-8 函数 imagefill() 的 参数 说 明 


参 数 说 明 














image | 规定 由 imagecreate0 或 imagecreatetruecolor0 创 建 的 图 像 标识 符 
wy | 开始 填充 的 点 的 坐标 。x、y 以 像素 为 单位 
color 填充 的 颜色 
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【实例 11-10】 使 用 函数 imagefill0 填 充 图 形 。 


<?php 
header ("Content-type:image/jpeg"); 
$im=imagecreate (300,200); // 创建 画布 
$color=imagecolorallocate ($im, 215, 215, 215); // 画 布 的 填充 颜色 
$colorl=imagecolorallocate ($im, 10, 20,100); // 边 线 的 颜色 
imagearc ($im, 60,100, 100,100, 0,360, $color1); // 画 圆 
imagefill ($im, 60,100, $color1); // 填 充 圆 
imagejpeg ($im); // 输 出 JPEG 图 像 
imagedestroy ($im); // 销 毁 图 像 资 源 
?> 


程序 运行 结果 如 图 11-10 所 示 。 





图 11-10 ”实例 11-10 运行 结果 
imagefilltoborder() 函 数 的 语法 格式 如 下 : 
bool imagefilltoboder (resource image,int x,int y,int boder,int color) 


函数 功能 :从 坐标 点 (x,y) 开 始 ， 用 颜色 color 开始 填充 ， 直 到 遇 到 颜色 为 boder 的 边界 
为 止 。 
函数 的 参数 说 明 如 表 11-9 所 示 。 
表 11-9 函数 imagefilltoboder() 的 参数 说 明 











参 数 说 明 
image | 规定 由 imagecreate0) 或 imagecreatetruecolorO 创 建 的 图 像 标识 符 
X，Y 开始 填充 的 点 的 坐标 。x、y 以 像素 为 单位 





boder 填充 边界 的 颜色 





color 填充 的 颜色 


【实例 11-11】 使 用 函数 imagefilltoborder() 填 充 图 形 。 


<?php 
header ("Content-type:image/jpeg"); 
$im=imagecreate (300, 200); // 创建 画布 
$color=imagecolorallocate ($im, 215, 215, 215); // 画 布 的 填充 颜色 
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$colorl=imagecolorallocate ($im,10,20,100); // 边 线 的 颜色 
$color2=imagecolorallocate ($im,150,150,150); // 填 充 的 颜色 
imagearc ($im, 60,100,100,100,0,360, $color1); // 画 圆 
imagefilltoborder ($im, 60,100, $color]l, $color2); // 填 充 圆 
imagejpeg ($im) // 输 出 JPEG 图 像 
imagedestroy ($im); // 销 毁 图 像 资源 


人 


程序 运行 结果 如 图 11-11 所 示 。 





图 11-11 实例 11-11 运行 结果 


性 提示 : 使 用 imagefilltoborder() 函 数 进行 填充 时 ， 边 界 内 的 所 有 颜色 都 会 被 填充 ， 如 
果 指 定 的 边界 色 和 该 点 闫 色相 同 ， 则 没有 填充 ; 如 果 图 像 中 没有 该 边界 
色 ， 则 整 幅 图 像 都 会 被 填充 。 
2. 矩形、 多 边 形 和 椭圆 形 的 填充 
PHP 还 提供 了 填充 矩形 、 多 边 形 和 椭圆 形 的 函数 ， 如 imagefilledrectangle()、 
imagefilledpolygon 和 imagefilledellipse()。 
这 三 个 函数 的 使 用 方法 是 相同 的 ， 这 里 仅 对 imagefilledrectangle0 函 数 进行 讲解 。 该 函 
数 的 语法 格式 如 下 : 
bool imagefilledrectangle (resource image,int xl,int yl,int x2,int y2,int 
color) 
函数 功能 : 在 image 图 像 中 绘制 一 个 矩形 ， 并 用 颜色 color 填充 该 矩形 。 和 矩形 左上 和 角 
的 坐标 为 (x1,y1)， 右 下 角 的 坐标 为 (x2,y2)。 
函数 的 参数 说 明 如 表 11-10 所 示 。 
表 11-10 函数 imagefilledrectangle() 的 参数 说 明 





参 数 说 明 


规定 由 imagecreate0 或 imagecreatetruecolor0 创 建 的 图 像 标 识 符 








矩形 左上 角 的 坐标 
x2, 72 矩形 右 下 角 的 坐标 
color 填充 矩形 的 颜色 
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【实例 11-12】 使 用 函数 imagefilledrectangle() 绘 制 并 填充 图 形 。 


<?php 
header ("Content-type:image/jpeg"); 
$im=imagecreate (300, 200); // 创 建 画 布 
$col=imagecolorallocate ($im, 215, 215, 215); // 画 布 的 填充 颜色 
$coll=imagecolorallocate ($im, 10, 20,100); // 填 充 的 颜色 
imagefilledrectangle ($im, 60, 60,180,150, $col11); // 绘 制 并 填充 矩形 
imagejpeg ($im); // 输 出 JPEG 图 像 
imagedestroy ($im); // 销 毁 图 像 资源 


程序 运行 结果 如 图 11-12 所 示 。 


园 ,ecple ii-iz php (300 x 
所 © DB localhost/e: 





11-12 ”实例 11-12 运行 结果 
11.2.8 ”绘制 文字 


在 PHP 程序 中 ， 可 以 通过 GD2 函数 库 来 绘制 英文 字符 串 ， 也 可 以 绘制 中 文字 符 串 。 
1. 绘制 英文 字符 串 

绘制 英文 字符 串 可 以 应 用 imagestring0 函 数 ， 其 语法 格式 如 下 : 

bool imagestring (resource image,int font,int x,int y,string str,int color) 


函数 功能 : 用 color 颜色 将 字符 串 str 水 平 绘制 到 image 所 代表 的 坐标 (x,y) 处 。 其 中 
坐标 (x,y) 是 指 字 符 串 左上 角 的 坐标 。 若 font 的 值 为 1、2、3、4 或 5， 则 使 用 内 置 字体 。 
【实例 11-13】 使 用 imagestring(O) 函 数 绘制 英文 字符 串 。 











<?php 
header ("Content-type:image/jpeg"); 
$im=imagecreate (300,100); // 创 建 画布 
$col=imagecolorallocate ($im, 215, 215, 215); // 画 布 的 填充 颜色 
$coll=imagecolorallocate ($im, 0,0,0); // 英 文字 符 串 的 颜色 
imagestring ($im, 5,85,45, "hello PHP", $col1); // 绘 制 字 符 串 
imagejpeg ($im); // 输 出 JPEG 图 像 
imagedestroy ($im); // 销 和 毁 图 像 资源 

> 
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程序 运行 结果 如 图 11-13 所 示 。 


4 © | localhost/exanmple_11-13.php 3 





图 11-13 ”实例 11-13 运行 结果 


2. 绘制 中 文字 符 串 
绘制 中 文字 符 串 可 以 应 用 imagettftext() 函 数 将 中 文字 符 串 水 平 绘制 ， 其 语法 格式 如 下 : 


array imagettftext (resource image,float size,float angle,int x,int y,int 
color, string fontfile, string text) 


函数 功能 : 用 color 颜色 将 中 文字 符 串 text 绘制 到 image 所 代表 的 坐标 (x,y) 处 。 其 中 ， 
坐标 (x.y) 是 指 字符 串 左上 角 的 坐标 。 
函数 的 参数 说 明 如 表 11-11 所 示 。 
表 11-11 函数 imagettftext() 的 参数 说 明 








参 数 说 明 

image 规定 由 imagecreate0) 或 imagecreatetruecolorO 创 建 的 图 像 标 识 符 

Size 规定 字体 的 大 小 ， 单 位 为 磅 

angle 规定 字体 的 角度 ， 单 位 为 度 

X， 了 规定 文字 的 x 坐标 值 和 y 坐标 值 

color 规定 文字 的 颜色 

fontfile 规定 字体 的 文件 名 称 

text 规定 要 输出 的 中 文字 符 串 内 容 

【实例 11-14】 使 用 imagettftextO 函 数 绘制 中 文字 符 串 。 
<?php 
header ("Content-type:image/jpeg"); 
$text = iconv ("gb2312", "utf-8", "你 好 "); // 转 换 字符 串 的 编码 格式 
$im=imagecreate (300,100); // 创 建 画布 
$col=imagecolorallocate ($im, 215, 215, 215); // 画 布 的 填充 颜色 
$coll=imagecolorallocate ($im, 0,0,0); // 中 文字 符 串 的 颜色 
$font="simhei.ttf"; // 设 置 字体 为 简体 黑体 字 
imagettftext ($im, 30,0,100, 60, $coll, $font, $text); // 绘 制 字 符 串 
imagejpeg ($im); // 输 出 JPEG 图 像 
imagedestroy ($im); // 销 毁 图 像 资源 
ES 


程序 运行 结果 如 图 11-14 所 示 。 
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你 好 





图 11-14 ”实例 11-14 运行 结果 


说 明 :  。 由 于 GD2 函数 库 支持 的 是 UTF-8 编码 格式 的 中 文 ， 因 此 ， 在 使 用 函数 
imagettftext() 绘 制 中 文字 符 串 时 ， 一 定 要 将 所 绘制 的 中 文字 符 串 转换 为 
UTF-8 的 编码 格式 ， 否 则 不 能 正确 输出 ， 此 时 必须 使 用 函数 icnov() 将 字 
符 串 的 编码 格式 转换 为 UTF-8 编码 格式 。 
。 字体 文件 和 了 PHP 程序 文件 的 位 置 要 放置 准确 。 本 例 中 的 字体 文件 simhei.ttf 
(简体 黑体 ) 就 是 和 PHP 程序 文件 位 于 同一 文件 天 下 。 


11.3 ”综合 实 训 案例 


本 节 主 要 介绍 通过 GD2 函数 生成 图 形 验证 码 的 方法 。 

在 网 页 上 使 用 图 形 验证 码 主要 是 为 了 提高 站 点 的 安全 性 ， 避 免 网 页 被 恶意 重复 提交 。 
本 实例 结合 JavaScript 脚本 和 GD2 函数 设计 一 个 可 刷新 图 形 验证 码 ， 其 运行 结果 如 图 11-15 
所 示 。 


所 3 © Dlocalhost/check/chec 


验证 码 





图 11-15 图形 验 证 码 运行 结果 


下 面 介绍 具体 步 又 。 
(1) 创建 check.html 静态 网 页 文件 。 在 该 程序 文件 中 定义 form 表单 ， 在 表单 中 定义 文 
本 框 控件 。 程 序 代码 如 下 : 


<html> 

<head> 

<meta http-equiv="Content-Language" content="zh-cn"> 

<meta http-equiv="Content-Type" content="text/html; charset=gb2312"> 
<title> 图 形 验 证 码 </title> 

</head> 
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<body> 
<form action ="check code.php" method ="POST" > 
验证 码 <input type="text" name="sub_code" size="16" class="input" /> 
<script language="javascript"> 
// 生 成 随机 数 
Var numl=Math.round (Math.random()*100000000); 
// 截 取 随 机 数 的 前 4 个 字符 
Var num=numl .toString() .substr (0,4); 
// 将 截取 值 传递 到 图 像 处 理 页 中 
document .write ("<img name=codeimg src="'ValidatorCode.php?code="+num+"'>"); 
// 定 义 方法 ,重新 生成 验证 码 
function reCode(){ 
// 生 成 随机 数 
Var numl=Math.round (Math.random()*100000000) 7 
// 截 取 随 机 数 的 前 4 位 
Var num=numl .toString() .substr (0,4); 
// 将 截取 的 值 传递 到 验证 码 生 成 程序 中 
document .codeimg.src="ValidatorCode.php?code="+num; 
} 
</script> 
<a href="javascript:recode () " class="al"> 看 不 清 ， 重 新 点 击 </a> 
<p align="center"><input type="submit" value=" 提 交 " name="B1"> 
</form> 





</body> 

</html> 

(2) 创建 PHP 程序 文件 ValidatorCode.php。 该 程序 文件 的 功能 就 是 生成 图 像 验 证 码 。 
<?php 


session start (); 
header ('content-type:image/jpeg'); // 定 义 JPEG 格式 图 像 
$im = imagecreate(75, 25); // 定 义 画 布 
// 填 充 夯 布 
$backcolor= imagecolorallocate ($im, 200, 200, 200); 
imagefill ($im, 0, 0,$backcolor); 
$validatorCode = $_GET['code']; // 获 取 提 交 的 随机 数 
// 将 生成 的 验证 码 写 入 session 
$_SESSION["validatorCode"]=$validatorCode; 
// 设 置 验证 码 字 体 的 颜色 
$colorl= imagecolorallocate ($im, 0, rand (0,255), rand (0,255)); 
$color2= imagecolorallocate ($im, rand (0,255),0,rand(0,255)); 
$color3= imagecolorallocate ($im, rand (0,255), rand (0,255),0); 
// 使 用 GD2 函数 imagettftext () 分 别 绘制 4 个 字符 
imagettftext ($im, 12, 0, 1,18,$colorl, 

'simhei .ttf',substr ($validatorCode, 0, 1)); 
imagettftext ($im, 12, 0, 14,18,$color2, 

'simhei .ttf',substr ($validatorCode, 1, 1)); 
imagettftext ($im, 12, 0, 29,18,$color3, 

'simhei .ttf'",substr ($validatorCode, 2, 1)); 
imagettftext ($im, 12, 0, 45,18,$colorl, 
'simhei.ttf',substr($validatorCode, 3, 1)); 


[es. 
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imagejpeg ($im); // 生 成 JPEG 图 像 
imagedestroy ($im); // 销 毁 图 像 
有 


(3) 创建 PHP 程序 文件 check_code.php。 该 程序 文件 的 功能 就 是 检查 所 提交 的 验证 码 
与 生成 的 验证 码 是 否 相同 。 程 序 代码 如 下 : 
<?php 
session start (); 
header ("Content-Type:text/html;charset=gb2312"); 
$code=$_POST["sub_code"]; 
if($code==$_SESSION["validatorCode"]) 
echo "验证 码 一 致 "; 
else 
echo "验证 码 不 一 致 ! "; 
这 


本 章 小 结 


本 章 详细 介绍 了 PHP 中 图 形 图 像 的 处 理 方法 和 步骤 。 在 PHP 程序 中 处 理 图 形 图 像 首 
先 要 设置 画布 ， 然 后 可 以 在 画布 上 生成 图 像 、 绘 制 文字 ， 最 后 销毁 画布 。 


习 题 


1. 编写 程序 ， 在 页 面 上 绘制 一 个 三 角形 ， 三 个 点 的 坐标 依次 为 (20,20)、(130,130) 和 
(60,180)。 
2. 编写 程序 ， 在 页 面 上 绘制 一 个 圆 并 用 红色 (200,2,2) 填 充 。 
3. 编写 程序 ， 在 页 面 上 绘制 文字 ， 文字 内 容 为 “欢迎 你 登录 ”。 
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本 章 要 点 


@ 文件 的 打开 、 读 取 、 写 入 、 人 删除 、 移 动 及 重 命名 等 操作 
@ 目录 的 打开 、 读 取 、 创 建 及 删除 等 操作 
@ 文件 的 上 传 及 下 载 


学 习 目 标 


@ ”掌握 文件 的 打开 、 读 取 、 写 入 、 删 除 和 移动 等 操作 方法 
@ 掌握 目录 的 打开 、 读 取 、 创 建 和 删除 等 操作 方法 


12.1 文件 的 处 理 


在 PHP 编程 中 ， 经 常 采 用 数据 库 和 文本 文件 两 种 方式 存储 数据 。 对 于 大 量 的 数据 ， 适 
合 采用 数据 库存 储 数据 ， 若 只 有 少量 的 数据 ， 利 用 文件 来 存 取 是 非常 便捷 的 。 文 件 操作 可 
以 通过 PHP 提供 的 文件 系统 函数 来 完成 。 文 件 的 操作 一 般 按 以 下 3 个 步骤 进行 。 

@ 打开 文件 。 

@ 读 取 / 写 入 文件 。 





@ 关闭 文件 。 
12.1.1 打开 文件 

打开 文件 是 对 文件 继续 操作 的 第 一 个 步骤 。 可 以 使 用 函数 fopen() 来 完成 ， 该 函数 的 语 
法 格式 如 下 : 

resource fopen (string filename, string mode,bool use_include_path， 


resource context) 


函数 功能 : 


J 开 指 定 的 文件 。 如 果 打 开 失 败 ， 则 函数 返回 FALSE。 


函数 的 参数 说 明 如 表 12-1 所 示 。 


表 12-1 函数 fopen() 的 参数 说 明 








参 数 说 明 
filename 规定 要 打开 的 文件 
mode 规定 打开 文件 的 模式 ， 具 体 可 选 值 见 表 12-2 





use_include_path 





可 选 。 决 定 是 否 在 include_path(php.ini 中 的 选项 ) 定 义 的 目录 中 搜索 flename 文件 





context 可 选 。 称 为 上 下 文 ， 用 于 控制 流 的 操作 特性 
表 12-2 参数 mode 的 可 选 值 
参 数 说 明 
r 以 读 模 式 读 文件 ， 文 件 指针 位 于 文件 头 部 
以 写 模式 写 入 文件 ， 文 件 指针 位 于 文件 头 部 。 若 该 文件 已 存在 ， 则 该 
Ww 





文件 的 原 有 内 容 被 删除 ; 若 该 文件 不 存在 ， 则 函数 将 创建 这 个 文件 
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续 表 
参 数 方式 名 称 说 明 
只 写 以 写 模式 读 、 写 文件 ， 文 件 指针 位 于 文件 头 部 。 若 该 文件 已 存在 ， 则 
该 文件 的 原 有 内 容 被 删除 :车 该 文件 不 存在 ， 则 函数 将 创建 这 个 文件 
谨慎 写 以 写 模式 打开 文件 ， 从 文件 头 部 开始 写 入 。 若 文件 已 经 存在 ， 则 该 文 
件 不 会 被 打开 ， 函 数 返回 FALSE，PHP 将 产生 一 个 警告 
谨慎 写 以 读 / 写 模式 打开 文件 ， 从 文件 头 部 开始 写 入 。 若 文件 已 经 存在 ， 则 
该 文件 将 不 会 被 打开 ， 函 数 返 回 FALSE，PHP 将 产生 一 个 警告 
追加 以 追加 模式 打开 文件 ， 文 件 指针 指向 文件 尾部 。 若 文件 存在 ， 则 从 文 
件 尾部 追加 ; 若 该 文件 不 存在 ， 函 数 将 创建 这 个 文件 
以 追加 模式 打开 文件 ， 文 件 指针 指向 文件 尾部 。 若 文件 存在 ， 则 从 文 
交加 件 尾部 追加 或 读 取 ; 若 该 文件 不 存在 ， 函 数 将 创建 这 个 文件 
b 二 进 制 以 二 进 制 模式 打开 文件 ， 且 只 能 与 其 他 模式 组 合 使 用 
t 文本 用 于 与 其 他 模式 的 结合 ， 这 个 模式 只 是 Windows 系统 下 的 一 个 选项 
【实例 12-1】 使 用 函数 fopen0 打 开 指 定 的 文件 。 
<?php 
$file name="my_dat.txt"; 
$filel=fopen ($file name, "r"); // 以 只 读 方式 打开 文件 
$file2=fopen ($file name, "w+"); // 以 读 写 方式 打开 文件 
?> 
程序 运行 后 ， 若 没有 my_dat.txt 这 个 文件 ， 则 会 出 现 如 图 12-1 所 示 的 错误 信息 。 
Warning: fopen(my_dat. txt): failed to open stream: 
such file or directory in 
C: \xampp \htdocs\example_12-1.php on line 3 
图 12-1 没有 找到 指定 文件 的 警告 信息 
12.1.2 ” 读 取 文 件 


文件 打开 之 后 ， 就 可 以 对 文件 进行 读 取 和 写 入 操作 了 。 首 先 介绍 文件 的 读 取 。 文 件 的 
读 取 有 4 种 方式 : 读 取 一 个 字符 、 读 取 一 行 字符 串 、 读 取 任 意 长 度 的 字符 串 和 读 取 整 个 
文件 。 

1. 读 取 一 个 字符 : fgetc () 函 数 

函数 的 语法 格式 如 下 : 


string fgetc (resource handle) 
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函数 的 功能 : 从 文件 指针 指定 的 位 置 读 取 一 个 字符 ， 遇 到 EOF 则 返回 FALSE。 
函数 参数 说 明 如 表 12-3 所 示 。 





表 12-3 ”函数 fgetc() 的 参数 说 明 





规定 要 打开 的 文件 ， 为 函数 fopen0 的 返回 值 


【实例 12-2】 使 用 fgetc0 函 数 读 取 文 件 中 的 字符 。 
在 当前 文件 夹 下 创建 my_file.txt 文件 ， 向 文件 中 写 入 “Hello! PHP” 并 保存 。 


<?php 
$file name="my_file.txt"; 
$file_open=fopen ($file name, "r"); 
if(!$file_open) 
echo "文件 不 能 打开 ! "; 
else 
echo fgetc($file open); 





人 


程序 运行 结果 如 图 12-2 所 示 。 





12-2 ”实例 12-2 运行 结果 


2. 读 取 一 行 字符 : fgets () 函 数 和 fgetss() 函 数 
fgets() 函 数 的 语法 格式 如 下 : 
string fgets (resource handle,int length) 
函数 的 功能 : 从 文件 指针 中 读 取 一 行 字 符 。 
函数 参数 说 明 如 表 12-4 所 示 。 
表 12-4 函数 fgets() 的 参数 说 明 
参 数 说 明 
Handle | 规定 要 打开 的 文件 ， 为 函数 fopen0 的 返回 值 
Length 可 选 。 规 定 要 读 取 的 数据 长 度 
【实例 12-3】 使 用 fgets0 函 数 读 取 文件 。 
在 当前 文件 夹 下 创建 my_file.txt 文件 ， 向 文件 中 写 入 “Hello! PHP” 并 保存 。 
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<?php 
$file name="my file.txt"; 
$file open=fopen ($file name "r"); 
if(!$file open) 
echo "文件 不 能 打开 ! "; 
else 
echo fgets ($file open); 
> 


程序 运行 结果 如 图 12-3 所 示 。 


localhost/exasple_12-3 X 


人 © DB localhost 
Hello! PHP 





12-3 ”实例 12-3 运行 结果 
fgetss() 函 数 的 语法 格式 : 
string fgetss (resource handle,int length, string allowed tags) 


函数 的 功能 : 从 文件 指针 中 读 取 一 行 字符 ， 同 时 函数 会 过 滤 掉 被 读 取 内 容 中 的 HTML 
和 PHP 标记 。 
函数 参数 说 明 如 表 12-5 所 示 。 


表 12-5 函数 fgetss() 的 参数 说 明 


规定 要 打开 的 文件 ， 为 函数 fo 


可 选 。 规 定 要 读 取 的 数据 长 度 
allowed tags 可 选 。 规 定 哪些 标记 不 被 去 掉 





【实例 12-4】 使 用 fgetss0 函 数 读 取 整 个 文件 。 
在 当前 文件 夹 下 创建 my_file.txt 文件 ， 向 文件 中 写 入 字符 串 <p><b>Hello! PHP</b></p>。 


<?php 
$file name="my_file.txt"; 
$file_open=fopen ($file name, "r"); 
if(!$file_open) 
echo "文件 不 能 打开 ! "; 
else 
echo fgetss ($file open,1024,"<b>,<p>"); 
2 


程序 运行 结果 如 图 12-4 所 示 。 


:(201\. 


om 人 -Ri 站 





Hello! PHP 





图 12-4 ”实例 12-4 运行 结果 
3. 读 取 任 意 长 度 的 字符 : fread () 函 数 
fread() 函 数 的 语法 格式 如 下 : 


string fread(resource handle, int length) 


函数 的 功能 : 从 文件 指针 中 读 取 长 度 为 length 的 字符 串 。 函 数 在 读 到 length 个 字 节 或 
者 遇 到 EOF 时 停止 执行 ， 还 可 以 读 取 二 进 制 文件 。 

【实例 12-S】 使 用 fread0 函 数 读 取 文件 。 

在 当前 文件 夹 下 创建 my_file.txt 文件 ， 向 文件 中 写 入 “Hello! PHP”。 


<?php 
$file name="my_file.txt"; 
$file_open=fopen ($file name, "r"); 
if(!$file open) 
echo "文件 不 能 打开 ! "; 
else 
echo fread($file open, 6); // 读 取 6 个 字 节 
2 


程序 运行 结果 如 图 12-5 所 示 。 


加 1calhost /op1e_ -= x NS 


© D localhost/exaample_12-5.php 


Hello! 





图 12-5 ”实例 12-5 运行 结果 


[时 提示 : 对 于 中 文字 符 ， 每 个 字符 按 两 个 字 节 来 处 理 。 因 此 ， 若 my_file.txt 的 内 容 为 
“认真 学 习 PHP”， 则 实例 12-5 的 运行 结果 如 图 12-6 所 示 。 





图 12-6 使 用 fread() 函 数 读 取 中 文字 符 串 
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4. 读 取 整个 文件 : readfile() 函 数 、fle() 函 数 和 flle_get_contents() 函 数 
readfile() 函 数 的 语法 格式 如 下 : 
int readfile(string filename, bool use include path,resource context) 


函数 的 功能 : 读 取 一 个 文件 并 写 入 输出 缓冲 ， 读 取 成 功 则 返回 读 取 的 字 节 数 ， 否 则 返 
回 FALSE。 
函数 参数 说 明 如 表 12-6 所 示 。 


表 12-6 函数 readfile() 的 参数 说 明 








规定 要 读 取 的 文件 名 称 


use_include_path 可 选 。 是 否 支 持 在 include_path 中 搜索 文件 ， 若 支持 ， 则 将 该 值 设 为 TRUE 
context 可 选 。 规 定 文件 句柄 的 环境 。context 是 一 套 可 以 修改 流 的 行为 的 选项 





【实例 12-6】 使 用 readfile0) 函 数 读 取 文件 。 
在 当前 文件 夹 下 创建 my_file.txt 文件 ， 向 文件 中 写 入 以 下 两 行 字符 并 保存 
Hello! PHP 
你 好 ! World 
<pre> 
<?php 
header ("Content-Type:text/html;charset=gb2312"); 
$file name="my_file.txt"; 
readfile ($file name); 
?> 
</pre> 


程序 运行 结果 如 图 12-7 所 示 。 


园 localhosyexample 12 x 有 


nm © Dlocalhost/example 12-6.php 安 | 三 


Hello! PHP 
你 好 ! World 





12-7 ”实例 12-6 运行 结果 


[ 且 提示 :， readfileO 函 数 不 需 要 打开 文件 、 关 闭 文件 ， 不 需要 使 用 echo 等 输出 语句 ， 
直接 调用 函数 就 可 以 将 数据 输出 。 


file0 函 数 的 语法 格式 如 下 : 


array file(string filename,int use include path,resource context) 


函数 的 功能 : 读 取 整个 文件 的 内 容 到 一 个 数组 中 。 读 取 成 功 则 返回 数组 ， 数 组 中 的 每 
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一 个 元 素 对 应 文件 中 的 一 行 (包括 换行 符 ); 读 取 失 败 则 返回 FALSE。 





函数 参数 的 含义 与 函数 readfile( 的 参数 含义 一 致 。 
【实例 12-7】 使 用 file0 函 数 读 取 文件 。 


<pre> 

<?php 
header ("Content-Type:text/html;charset=gb2312"); 
$file name="my_file.txt"; 
$a=file ($file_name); // 将 读 出 的 内 容 存 入 数组 a 中 
echo $a[0]; 
echo $a[1]7 


程序 运行 结果 如 图 12-8 所 示 。 


localhost/example_12 
€ © DD localhost/example 12-7 


Hello! PHP 
你 好 ! World 





图 12-8 实例 12-7 运行 结果 


file_get_contents() 函 数 的 语法 格式 如 下 : 


string file get contents (string filename,bool use_include path, resource 
context, int offset,int maxlength) 


函数 的 功能 .将 整个 文件 的 内 容 读 入 到 一 个 字符 串 中 。 如 果 有 offset 和 maxlength 参 


数 ， 则 在 offset 指定 的 位 置 读 取 长 度 为 maxlength 的 内 容 。 如 果 读 取 失 败 ， 函 数 返 回 
FALSE。 该 函数 也 适用 于 二 进 制 文件 。 


函数 参数 说 明 如 表 12-7 所 示 。 
表 12-7 函数 file_get_contents() 的 参数 说 明 


参 数 说 明 





规定 要 读 取 的 文件 名 称 


filename 





use_include_path 


可 选 。 是 否 支持 在 include_path 中 搜索 文件 。 若 支持 ， 则 将 该 值 设 为 TRUE 











context 可 选 。 规 定 文件 句柄 的 环境 。context 是 一 套 可 以 修改 流 的 行为 的 选项 
offset 可 选 。 规 定 在 文件 中 开始 读 取 的 位 置 
maxlength 可 选 。 规 定 可 以 读 取 数据 的 最 大 长 度 


【实例 12-8】 使 用 fie_get_contents() 函 数 读 取 文件 。 
<pre> 
<?php 
header ("Content-Type:text/html;charset=gb2312"); 
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$file name="my file.txt"; 

echo file get contents ($file name); 
2> 
</pre> 


程序 运行 结果 如 图 12-9 所 示 。 


© | localhost 


Hello! PHP 
你 好 ! World 





图 12-9 实例 12-8 运行 结果 
12.1.3” 写 入 文件 


向 文件 中 写 入 数据 可 以 使 用 fwrite0 函 数 和 file_ put_contents() 函 数 。 

fwrite0 函 数 的 语法 格式 如 下 : 

int fwrite (resource handle, string str,int length) 

函数 功能 : 将 内 容 str 写 入 文件 指针 handle 处 。 如 果 指 定 了 长 度 length， 当 写 入 了 
length 个 字 节 后 就 会 停止 。 若 写 入 成 功 ， 函 数 返 回 写 入 的 字符 数 ， 写 入 失败 ， 函 数 返回 
FALSE。 

函数 的 参数 说 明 如 表 12-8 所 示 。 

表 12-8 函数 fwrite() 的 参数 说 明 


规定 要 写 入 的 文件 ， 为 函数 fopen0 的 返回 值 


规定 写 入 文件 的 字符 串 
可 选 。 规 定 写 入 文件 的 字 节 数 


【实例 12-9】 使 用 fwriteO 函 数 写 文件 。 


<?php 
header ("Content-Type:text/html;charset=gb2312"); 
$str="Hello PHP"; 
if(!$file open=fopen ("my_dat .dat","w")) 
echo "打开 文件 失败 ! "5 
else 
{ 
if(!fwrite ($file open, $str)) 
echo " 写 入 失败 ! "; 
else 


echo " 写 入 成 功 ! "; 
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file_put_contents() 函 数 的 语法 格式 如 下 : 


int file put contents (string filename, string data,int flag,resource 
context) 


函数 功能 : 将 一 个 字符 串 写 入 文件 。 若 写 入 成 功 ， 函 数 返 回 写 入 的 字 节 数 ， 失 败 则 函 
数 返 回 FALSE。 该 函数 也 适用 于 二 进 制 文件 。 
函数 的 参数 说 明 如 表 12-9 所 示 。 
表 12-9 函数 file_put_contents() 的 参数 说 明 














参 数 说 明 
filename 规定 要 写 入 的 文件 名 称 
data 规定 写 入 的 数据 
可 选 。 规 定 对 文件 的 锁定 。 可 选 的 值 有 3 个 。 
FILE_USE_INCLUDE PATH: 在 include 目录 里 搜索 文件 ; 
FILE_APPEND: 文件 指针 移 至 文件 末尾 追加 数据 ; 
LOCK_EX: 独占 锁定 
context 可 选 。 一 个 context 资源 


【实例 12-10】 使 用 file_put_contents0 函 数 写 文件 。 


<?php 
header ("Content-Type:text/html;charset=gb2312"); 
$str=" 你 好 ! PHP"; 
if(!file put contents ("my dat.dat", $str)) 
echo " 写 入 失败 ! "; 
else 
echo " 写 入 成 功 ! "; 








flags 





?> 


12.1.4 关闭 文件 


对 文件 读 / 写 完成 后 ， 就 要 关闭 该 文件 。 在 PHP 中 可 以 使 用 feloseO 函 数 关闭 文件 。 
feloseO) 函 数 的 语法 格式 如 下 : 


bool fclose (resource handle) 


函数 功能 :将 参数 handle 指向 的 文件 关闭 。 若 关闭 成 功 ， 则 函数 返回 TRUE， 和 否则 函 
数 返 回 FALSE。 其 中 handle( 文 件 句柄 ) 必 须 是 有 效 的 ， 而 且 是 通过 fopen() 函 数 成 功 打开 的 
文件 。 

【实例 12-11】 使 用 fclose0 函 数 关闭 文件 。 

<?php 


header ("Content-Type:text/html;charset=gb2312"); 
$str="Hello PHP"; 
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Sopen=fopen ("my_dat .dat", "w")) V7 打开 交 件 
fwrite ($file open, $str); // 写 入 文件 
fclose($open); // 关 闭 文件 


区 2 


12.1.5 ”删除 文件 


删除 文件 可 以 使 用 函数 unlik() 来 实现 。 该 函数 的 语法 格式 如 下 : 
bool unlik(string filename) 
函数 功能 : 删除 指定 的 文件 。 如 果 成 功 ， 则 函数 返回 TRUE， 和 否则 返回 FALSE。 使 用 
函数 时 ， 一 定 要 保证 文件 是 关闭 的 。 
【实例 12-12】 使 用 函数 unlikO 删 除 文件 。 
<?php 


unlik("my_file.dat"); 
六 





12.1.6 ”复制 文件 


复制 文件 可 以 使 用 函数 copy0 来 实现 。 该 函数 的 语法 格式 如 下 : 
bool copy(string source, string destination) 


函数 功能 ， 将 文件 从 参数 source 处 复制 到 参数 destination 处 。 若 复制 成 功 则 函数 返回 
TRUE， 和 否则 返回 FALSE。 
函数 参数 说 明 如 表 12-10 所 示 。 
表 12-10 ”函数 copy() 的 参数 说 明 


说 明 
规定 要 复制 的 文件 
规定 复制 文件 的 目的 地 


【实例 12-13】 使 用 函数 copy0 复 制 文件 。 


<?php 
header ("Content-Type:text/html;charset=gb2312"); 
$file_source="my_file.txt"; // 原 文件 
$file dest="./data/file2.txt"; // 新 文件 的 路 径 及 名 称 
if(copy ($file source, $file dest)) 
echo "文件 复制 成 功 ! "; 
else 


echo "文件 复制 失败 1"; 


source 








destination 


> 
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12.1.7 ”移动 和 重 命名 文件 


使 用 函数 rename() 可 以 实现 为 文件 重 命名 和 移动 的 功能 。 该 函数 的 语法 格式 如 下 : 
bool rename(string oldname, string newname) 


函数 功能 : 将 文件 oldname 重新 命名 为 newname。 车 成 功 ， 则 函数 返回 TRUE， 否 则 
返回 FALSE。 该 函数 也 可 以 将 指定 的 文件 移动 到 另 一 路 径 下 而 不 改变 文件 名 称 。 
【实例 12-14】 使 用 函数 rename() 文 件 重新 命名 并 移动 到 新 的 文件 夹 下 。 
<?php 
header ("Content-Type:text/html;charset=gb2312"); 
$0old name="my_file.txt"; 
$new_name="my_newfile.txt"; 








if(rename ($01ld name, $new_name)) // 重 新 命名 文件 
echo "文件 重新 命名 成 功 ! "; 
if(rename (Snew_name,"./data/Snew_name") ) // 将 更 名 后 的 文件 移动 到 
//data 文件 夹 下 


echo "文件 移动 成 功 ! "; 


?> 


12.2 目录 操作 


在 PHP 中 ， 目 录 是 一 种 特殊 的 文件 ， 要 对 其 进行 操作 ， 也 要 进行 先 打开 ， 再 进行 浏 
览 、 操 作 ， 最 后 还 要 关闭 。 


12.2.1 打开 目录 


在 PHP 中 打开 目录 可 以 使 用 函数 opendir0 来 实现 。 该 函数 的 语法 格式 如 下 : 
resource opendir (string path,resource context) 
函数 功能 :打开 指定 的 目录 。 如 果 打 开 目 录 成 功 ， 则 函数 返回 指向 目录 的 指针 ; 如 果 
参数 path 指定 的 不 是 一 个 有 效 的 目录 ， 或 者 因为 权限 不 足 、 文 件 系 统 错误 而 不 能 打开 目 
录 ， 函 数 将 返回 FALSE， 并 产生 警告 信息 。 
【实例 12-15】 使 用 函数 open dir0 打 开 指 定 的 目录 。 
<?php 
$dir="./data"; 
if(is dir($dir)) 


opendir ($dir); 
?> 


[对 提示 : ”使 用 opendirO 函 数 打开 目录 前 ， 尽 量 使 用 函数 is_dir0 来 检查 一 下 想 要 打开 
的 目录 是 否 存在 。 
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12.2.2 ” 读 取 目录 





目录 打开 后 就 可 以 使 用 函数 readdir0 读 取 该 目录 下 的 数据 了 。 该 函数 的 语法 格式 如 下 : 
string readdir (resource dir handle) 
函数 功能 : 读 取 指定 目录 下 的 数据 。 执 行 该 函数 ， 返 回 目录 下 的 一 个 文件 名 ， 读 取 结 
束 时 返回 FALSE。 
函数 参数 说 明 如 表 12-11 所 示 。 

表 12-11 函数 readdir() 的 参数 说 明 


























规定 要 使 用 的 目录 指针 ， 该 值 为 o 


【实例 12-16】 使 用 函数 readdir0 读 取 指 定 的 目录 。 


<?php 
$dir="./xampp"; 
if(is_dir($qdir)) // 检 查 目录 是 否 存在 
{ 
if ($dir_open=opendir($dir)) // 打 开 指 定 目录 
{ 
while ($con=readdir ($dir_open)) // 读 取 目 录 下 数据 
echo $con,"<br.>"; 


2 


程序 运行 结果 如 图 12-10 所 示 。 


bm CG DD localhost 


.modell 
.modell-usb 
“Version 





图 12-10 ”实例 12-16 运行 结果 
12.2.3 ”关闭 目录 


目录 操作 完毕 ， 就 要 关闭 目录 了 。 使 用 函数 closedirO 可 以 关闭 目录 ， 函 数 的 语法 格式 
如 下 : 


void closedir(resource dir handle) 


函数 的 功能 : 关闭 由 opendir0 打 开 的 目录 句柄 。 
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函数 参数 dir_handle 的 含义 与 readdir() 函 数 的 参数 dir handle 含义 一 致 。 
【实例 12-17】 使 用 函数 closedirO 关 闭 目录 。 


<?php 
$dir="./xampp"; 
$open=opendir ($dir); 
closedir ($open); 

?> 


12.2.4 创建 目录 


创建 目录 可 以 通过 mkdir0 来 实现 。 该 函数 的 语法 格式 如 下 : 

bool mkdir(string pathname, int mode,bool recursive,resource context) 

函数 功能 : 创建 以 pathname 命名 的 目录 。 若 创建 成 果 ， 函 数 返 回 TRUE， 和 否则 返回 
FALSE。 

函数 参数 说 明 如 表 12-12 所 示 。 


表 12-12 ”函数 mkdir() 的 参数 说 明 





参 数 说 明 
athname 规定 要 创建 的 目录 的 名 称 
mode 可 选 。 规 定 权限 ， 以 八进制 方式 指定 ， 默 认为 0777( 最 大 权限 ) 
recursive 可 选 。 规 定 是 否 设 定 递归 模式 
context 可 选 。 规 定 文件 句柄 的 环境 


【实例 12-18】 使 用 函数 mkdir0 创 建 目录 。 


<?php 
header ("Content-Type:text/html;charset=gb2312"); 
$pathname="testing"; 
if (is_qir ($pathname)) // 检 查 该 目录 是 否 已 存在 
echo "该 文件 夹 已 存在 ! "; 
else 


mkdir ($pathname); ”// 创 建 目录 
2> 


12.2.5 ”删除 目录 


删除 目录 可 以 通过 函数 mmdir0 来 实现 。 该 函数 的 语法 格式 如 下 : 

int rmdir (string pathname,resource context) 

函数 功能 : 删除 一 个 空 目录 。 若 删除 成 功 ， 函 数 将 返回 TRUE， 和 否则 返回 FALSE。 所 
要 删除 的 目录 必须 是 空 的 ， 而 且 权限 必须 符合 要 求 。 

函数 参数 说 明 如 表 12-13 所 示 。 
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表 12-13 ”函数 rmdir() 的 参数 说 明 


3 
滋 


说 明 





规定 要 创建 的 目录 的 名 称 
可 选 。 规 定 文件 句柄 的 环境 


【实例 12-19】 使 用 函数 mmdir0) 删 除 目录 。 


<?php 
header ("Content-Type:text/html;charset=gb2312"); 
$pathname="testing"; 
if(is_dir ($pathname))  ”// 检 查 该 目录 是 否 已 存在 
rmdir ($pathname); ”// 删 除 目录 
else 


echo "该 目录 不 存在 ! "; 


pathname 





Context 





> 


12.2.6 ”改变 目录 

在 PHP 中 对 于 已 经 打开 的 目录 ， 如 果 要 转 到 另 一 个 目录 ， 可 以 使 用 函数 _chdir0 来 实 
现 。 该 函数 的 语法 格式 如 下 : 

bool chdir(string directory) 

函数 功能 : 从 当前 所 在 目录 转换 到 指定 的 目录 。 若 转换 成 功 ， 函 数 返回 TRUE， 和 否则 
返回 FALSE。 

函数 参数 说 明 如 表 12-14 所 示 。 

表 12-14 函数 chdir() 的 参数 说 明 





规定 要 转换 到 的 新 目录 


【实例 12-20】 使 用 函数 chdir0 转 换 目 录 。 
<?php 
$openl=opendir("./testing");  // 进 入 目录 testing 
closedir ($open1); 


chdir ("./xampp"); // 转 换 到 目录 xampp 
2 


12.3 ”文件 上 传 与 下 载 
12.3.1 相关 设置 


1. php.ini 文 件 设置 
要 想 在 PHP 程序 中 顺利 实现 文件 上 传 功能 ， 首 先 要 在 php ini 文件 中 设置 文件 上 传 的 
.CEIT. 
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一 些 选项 。 找 到 File_Uploads 项 ， 分 别 设置 以 下 选项 。 
@ file uploads: 值 为 on， 表 明 服 务 器 支持 文件 上 传 ， 否 则 不 支持 。 
@ uploads tmp _ dir: 上 传 文件 的 临时 目录 。 文 件 在 成 功 上 传 之 前 首先 被 保存 在 该 目 
录 下 。 
@ uploads max filesize: 服务 器 允许 上 传 文件 的 最 大 值 。 
相关 配置 如 图 12-11 所 示 。 


| 辣 回 加 
Er TT 











BR 


file_uploads=On ja 
upload_tmp_dir="C:\xampp\tmp" 
upload_max_filesize=2M 
max_file_uploads=20 
轴 





12-11 ”php.ini 中 关于 文件 上 传 的 选项 设置 
2. 全 局 变量 $_FILES 


全 局 变量 $_FILES 存储 的 是 上 传 文件 的 相关 信息 ， 该 变量 是 一 个 二 维 数组 ， 其 存储 的 
信息 如 表 12-15 所 示 。 


表 12-15 全 局 变量 $_FILES 存储 的 信息 


元 素 名 说 明 
$_FILES[filename]["name"] 存储 了 上 传 文件 的 名 称 
$_FILES[filename]["size"] 存储 了 上 传 文件 的 大 小 ， 单 位 为 字 节 
$_FILES[filename]["tmp_name" 存储 了 上 传 文件 被 存储 的 临时 目录 
$_FILES[filename]["typer 存储 了 上 传 文件 的 类 型 
$_FILES[filename]["error" 存储 了 上 传 文件 的 结果 。 若 为 0， 说 明 上 传 成 功 

12.3.2 文件 上 传 


PHP 主要 使 用 move_uploaded_file() 函 数 以 及 全 局 变量 $_FILE 来 实现 文件 上 传 。 
move_uploaded_file() 函 数 的 语法 格式 如 下 : 

bool move_ uploaded file(string filename, string destination) 

函数 功能 : 将 文件 上 传 到 指定 的 目录 下 。 如 果 上 传 成 功 ， 函 数 返回 TRUE， 否 则 返回 
FALSE。 

函数 参数 说 明 如 表 12-16 所 示 。 
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表 12-16 函数 move u 
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ploaded file() 的 参数 说 明 








参 数 含 义 
filename 规定 上 传 文件 的 临时 名 称 
destination 规定 文件 上 传 后 新 的 路 径 及 名 称 
全 上 传单 个 文件 


【实例 12-21】 将 一 个 文件 上 传 到 服务 器 

首先 创建 一 个 静态 网 页 文件 filehtml， 志 
属性 值 为 up_file)。 代 码 如 下 : 

<html> 


<head> 
<meta http-equiv="Content-Language 


<meta http-equiv="Content-Type" con 


</head> 
<body> 


<table border="0" width="790" cellp: 


collapse"> 


中 包含 form 表单 及 一 个 文件 上 传 控件 (name 





”content="zh=cn"> 
tent="text/html; charset=gb2312"> 


adding="0" style="border-collapse: 


<form method="POST" enctype="multipart/form-data" 


action="uoload file.php"> 
<tr> 
<td width="178"> 
<td> 
size="76"></p></td> 
</tr> 
<tr> 


<p alig 


n="right"> 文 件 </td> 


<p align="left"><input type="file" name="up_file" 


<td colspan="2"><p align="center"><input type="submit" value=" 提 


交 " name="B1"></td> 
</tr> 
</form> 
</table> 
</body> 
</html> 


文件 启动 如 图 12-12 所 示 。 








OE /es PH) Bi x [ml < 
文件 四 编 田 如 ”查看 WD 收藏 大 内 工具 上 帮助 由 
文件 | 浏览 ... 
提交 





图 12-12 file.html 文件 启动 界面 


创建 upload file php 文件 ， 该 程序 文件 


的 功能 是 将 文件 上 传 至 服务 器 的 指定 文件 夹 


(a. 
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下 。 程序 代 码 如 下 : 


<?php 
header ("Content-Type:text/html;charset=gb2312"); 
// 判 断 是 否 有 上 传 文件 
if(!empty($_FILES["up file"] ["name"])) 
{ 
// 获 取 上 传 文件 的 临时 文件 名 
$file name=$_FILES["up_ file"] ["tmp name"]; / 
// 上 传 的 目录 及 新 文件 名 
$destination="./upload/my file.dat"; 
if($_FILES["up_file"] ["size"]>1000000) 
echo "文件 太 大 "; 
else { 
/7 上 传 文件 
move_uploaded file($file name, $destination); 


echo "文件 上 传 成 功 ! "; 


?> 


[ 提示 : 使 用 move_uploded file0) 函 数 上 传 文件 ， 在 创建 form 表单 时 ， 必 须 设置 表 
单 属性 entype="multipart/form-data"。 


2: 上 传 多 个 文件 


在 上 传 多 个 文件 时 ， 可 以 在 表单 中 对 文件 上 传 控件 使 用 数组 命名 。 

【实例 12-22】 将 多 个 文件 上 传 到 服务 器 。 

首先 创建 一 个 静态 网 页 文件 file.html， 内 含 form 表单 及 三 个 文件 上 传 控 件 (名 称 命名 
为 数组 形式 up_file[])。 代 码 如 下 : 


<html> 

<head> 

<meta http-equiv="Content-Language" content="zh-cn"> 
<meta http-equiv="Content-Type" content="text/html; charset=gb2312"> 
</head> 

<body> 

<form method="POST" enctype="multipart/form-data" 
action="upload file.php"> 

文件 1<input type="file" name="up_file[]" size="50"><br> 
文件 2<input type="file" name="up_file[]" size="50"><br> 
文件 3<input type="file" name="up_file[]" size="50"><br> 
<input type="submit" value=" 提 交 " name="Bl1"> 

</form> 

</body> 

</html> 


创建 upload_file.php 文件 ， 程 序 代 码 如 下 : 


<?php 
header ("Content-Type:text/html;charset=gb2312"); 
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// 将 上 传 文件 的 名 称 存 入 数组 $Sfile_name 
$file name=$_FILES["up file"] ["name"]; 
// 将 上 传 文件 的 临时 名 称 存 入 数组 $Sfile_tmp_name 
$file tmp name =$_FILES["up file"] ["tmp name"]; 
// 文 件 上 传 的 目录 
$dest="./upload/™"; 
// 利 用 循环 将 文件 逐个 上 传 
for ($i=0;$i<count ($file name); $i++) 
{ 
// 判 断 上 传 文件 名 是 否 为 空 
if(!empty ($file name)) 
{ 
move_uploaded file($file tmp name[$i],$dest."$i".".txt"); 
echo "文件 ".$file_name[$i] ." 上 传 成 功 ! <br/>"; 
} 


程序 运行 结果 如 图 12-13 和 图 12-14 所 示 。 


http://localhost/file. htal - Internet Erplorer [- [DT xj 


GO- 回 es aocahesvs D9) Eicon | 这 
文件 四 编 竹 四。 查看 轨 。 收藏 大 W， 工具 加 部 助人 0 








文件 ] 欧 UsersWhdainistrator\Desktop\2015-2016 年 度 校 历 . de 。 浏览,,. 
文件 下 :WUssrsWasinistrator\Desktop\2015 主 持 河 " docx 浏览. , 。 
文件 EM Users Adeinistrator\Desktop\ 维 续 教 育 广 册 .doc 浏览. ， 








12-13 ”file.html 运行 结果 









lhost/upload file. php — In 

http://localhost/np 及 可 1 好 Da x ll 个 
文件 四 编辑 外 查看 外 收藏 只 WW) 工具 GD 帮助 0 

文件 2015-2016 年 度 校 历 . doc 上 传 成 功 ! 


文件 2015 主 持 词 . docx 上 传 成 功 ! 
文件 继续 教育 注册 . doc 上 传 成 功 ! 








12-14 ”多 个 文件 上 传 的 运行 结果 


12.3.3 文件 下 载 
在 PHP 中 下 载 文件 ， 可 以 通过 以 下 两 种 方式 进行 。 
通过 链接 方式 下 载 
页 中 通过 链接 下 载 的 格式 如 下 : 


<a href="my_file.doc"> 目 录 </a> 
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在 网 页 上 通过 鼠标 点 击 链接 ， 就 可 以 下 载 相应 的 文件 了 。 
2. 应 用 header() 函 数 实 现下 载 
header() 函 数 的 语法 格式 如 下 : 
void header (string header,bool replace,int http response code) 
函数 功能 :该 函数 送出 HTTP 协议 的 标 头 到 浏览 器 。 其 中 HTTP 下 载 的 标 头 格式 为 : 
header ("Content-Disposition:attachment;filename= 文 件 名 ") 
这 里 需要 改动 的 就 是 文件 名 了 。 
函数 的 参数 说 明 如 表 12-17 所 示 。 
表 12-17 函数 header() 的 参数 说 明 





参 数 含义 
Header 规定 要 发 送 的 报头 字符 串 
可 选 。 指 示 报 头 是 否 蔡 换 之 前 的 报头 ， 或 添加 第 二 个 报头 。 默 认为 
Replace 


TRUE( 蔡 换 )，FASLE 则 允许 相同 类 型 的 多 个 报头 
可 选 。 把 HTTP 响应 代码 强 置 为 指定 的 值 


【实例 12-23】 使 用 函数 headerO 下 载 文件 。 


<?php 
// 对 所 下 载 的 文件 进行 描述 
$file="my_dat.dat"; 
header ("Content-Disposition:attachment;filename=$file"); 
// 通 过 readfile () 函数 读 取 文件 
readfile ($file); 





http_response_code 


?2> 


程序 运行 结果 如 图 12-15 所 示 。 











要 打开 或 保存 未 让 localkest 的 “ny_dot. 4st” C22 字 节 )17 


打开 四 保存 中 |”| 9 消 四 














图 12-15 ”实例 12-22 运行 结果 图 
12.4 ”综合 实 训 案例 


本 节 主 要 介绍 利用 PHP 文件 上 传 的 功能 实现 提交 C 语言 作业 的 页 面 。 
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1. 分 析 


创建 一 个 静态 网 页 文件 homwork.html， 其 中 包含 form 表单 ((enctype 属性 值 为 
"multipart/form-data"，method 为 "POST" 方 式 ) 和 文件 上 传 控 件 (name 属性 值 为 "up_file")。 文 
件 启动 界面 如 图 12-16 所 示 。 


< 人 


欢迎 使 用 C 语 言 作 业 上 交 系统 


C 奏 序 文件 (*. c) ， [ 迁 拓 文件 | 1263104324c 





12-16 ”提交 作业 界面 


创建 PHP 程序 文件 upload_file.php， 该 文件 的 功能 是 上 传 学 生 提 交 的 C 语言 作业 文件 
至 服务 器 指定 的 目录 “c_file” 下 ， 并 读 取 文件 的 内 容 ， 显 示 在 页 面 的 文本 域 控件 内 。 程 序 
运行 结果 如 图 12-17 所 示 。 


园 1ecalhost /wricss £10 x We 
€ 2 © |D localhost/upload fi 


#includeCstdio. b> 

void nainO 

{ float profit,bons; 
printf(“ 请 输入 利润 (万 元 ) : \n”); 
scanf (“%f, Wf”, Aprof1t) ; 
1f(profitC=10) bonus=profit#0.1; 


if(profit>10 hk profit(=20) bonus=profi t#0.075; 
1f(profit>20 && profitC=40) bonus=profi t+0.05; 
1f(profit)40 4& profit(=60) bonus=profi t+0,08; 
if(profit>60 && profitK=80) bonus=profit#0. 015; 
if(80Kprofit) bonus=profit#0, 01; 
printf( “奖金 总 数 <%f 万 元 "bonus) 





图 12-17 ”提交 成 功 并 显示 文件 内 容 
2. 程序 代码 
homework.html 文件 的 代码 如 下 : 


<html> 

<head> 

<meta http-equiv="Content-Language" content="zh-cn"> 

<meta http-equiv="Content-Type" content="text/html; charset=gb2312"> 
<title> 提 交 c 语言 作业 </title> 

</head> 

<body> 

<form method="POST" enctype="multipart/form-data" 

action="upload file.php"> 

<p align="center"><b> 欢 迎 使 用 c 语言 作业 上 交 系 统 </b></p> 

C 语言 程序 文件 (*.c): <input type="file" name="up_file" size="40"><br/> 
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<input type="submit" value=" 提 交 " name="Bl">&nbsp; &nbsp; 
<input type="reset" value=" 重 置 " name="B2"> 

</form> 

</body> 

</html> 


upload_file.php 程序 文件 代码 如 下 : 


<?php 
header ("Content-Type:text/html;charset=gb2312"); 
// 判 断 是 否 有 上 传 文件 
if(!empty($_FILES["up_file"] ["name"])) 
{ 
// 获 取 上 传 文件 的 临时 文件 名 
$file name=$_FILES["up_file"] ["tmp_name"]; 
// 上 传 的 目录 及 新 文件 名 
$destination="./c file/".$_FILES["up file"] ["name"]; 
if($_FILES["up_file"] ["size"]>1000000) 
echo "文件 太 大 "; 
else 
{ 
/7 上传 文件 
move_uploaded file($file name, $destination); 
// 读 取 文 件 并 显示 在 文本 区 内 
echo "<textarea rows=15 name=S1 cols=66 style='font-size: 
llpt';>", file get_ contents ($destination); 
echo "</textarea>"; 
} 


?> 


本 章 小 结 


本 章 详细 介绍 了 文件 、 目 录 和 上 传 文件 的 操作 及 相关 函数 。 文 件 操 作 包 括 : 打开 文件 、 
读 取 文件 、 写 入 文件 、 删 除 文件 和 复制 文件 ， 文 件 目录 的 操作 包括 : 打开 目录 、 读 取 目 录 、 
创建 目录 、 删 除 目录 和 改变 目录 ， 文 件 上 传 的 操作 包括 单个 文件 上 传 和 多 个 文件 上 传 。 


习 是 


. 设 有 文本 文件 my_file.txt， 按 读 取 字符 的 方式 读 取 文 件 的 内 容 。 

. 设 有 文本 文件 my_file.txt， 以 读 取 行 的 方式 读 取 文件 的 内 容 。 

. 设 有 文本 文件 my_file.txt， 以 读 取 整 个 文件 的 方式 读 取 文 件 的 内 容 。 
. 创建 文件 ， 将 文字 “欢迎 使 用 PHP” 写 入 文件 中 。 

. 将 图 片 文件 picl.jpg 上 传 到 服务 器 的 my_pic 目录 下 。 


内 上 mmPB 一 
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本 章 要 点 

@ 类 和 对 象 的 概念 

@ ”类 的 继承 和 重 载 的 概念 及 实现 方式 

@ ”接口 的 概念 和 具体 应 用 

学 习 目 标 

@ 掌握 类 和 对 象 的 概念 

@ 了 解 类 的 继承 和 重 载 的 概念 及 实现 方式 
@ 了 解 接口 的 概念 和 具体 应 用 


13.1 概 述 
13.1.1 面向 对 象 的 概念 


面向 对 象 就 是 将 要 处 理 的 问题 抽象 为 对 象 ， 然 后 通过 对 象 的 属性 和 行为 来 解决 对 象 的 
实际 问题 。 


13.1.2 ”PHP 面向 对 象 的 特点 


面向 对 象 的 编程 方式 具有 继承 、 封 装 和 多 态 性 等 特点 。 

@ ”继承 : 通过 继承 可 以 创建 子 类 和 父 类 之 间 的 层次 关系 ， 子 类 可 以 从 父 类 中 继承 属 
性 和 方法 ， 通 过 这 种 关系 模式 可 以 简化 类 的 操作 。 

@ ”封装 : 将 对 象 的 属性 隐藏 在 类 的 内 部 ， 而 将 调用 的 方法 暴露 给 调用 者 ， 后 者 无 需 
知道 方法 实现 的 细节 ， 只 经 定义 良好 的 接口 一 一 调用 对 象 方法 的 入 口 ， 使 之 具有 良 
好 的 重用 性 。 

@ 多 态 : 根据 使 用 类 的 上 下 文 来 重新 定义 或 改变 类 的 性 质 和 行为 。 但 是 PHP 不 支持 
重 载 来 实现 多 态 ， 不 过 可 以 变相 地 实现 多 态 效果 。 


13.2 ”类 和 对 象 


世间 的 万 物 都 有 其 自身 的 属性 和 方法 ， 通 过 这 些 属性 和 方法 可 以 将 不 同 的 物质 区 分 开 
来 。 比 如 说 人 具有 身高 、 体 重 、 肤 色 等 属性 ， 通 过 这 些 属性 ， 可 以 将 不 同 的 人 区 分 开 来 。 
另外 ， 人 还 具有 行走 、 吃 饭 、 睡 觉 等 活动 ， 这 些 活动 都 是 人 所 具有 的 功能 。 如 果 把 人 比 作 
程序 中 的 类 ， 那 么 人 的 身高 、 体 重 等 属性 就 是 类 的 属性 ， 人 的 行走 、 学 习 等 活动 就 是 类 的 
方法 。 

类 就 是 属性 和 方法 的 集合 ， 是 面向 对 象 编程 方式 的 基础 和 核心 。 类 不 能 直接 在 程序 中 
引用 ， 必 须 实 例 化 后 才能 使 用 。 

对 象 是 类 实例 化 后 的 产物 ， 是 一 个 实体 。 比 如 说 ， 人 是 一 个 “类 ”， 则 “黄种 人 ”就 
是 “人 ”这 个 类 的 一 个 实例 对 象 。 
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13.2.1 类 的 结构 与 声明 方式 


在 PHP 中 创建 类 时 ， 必 须 使 用 关键 字 class 进行 声明 。 类 的 声明 格式 如 下 : 


[权限 修饰 符 ] class 类 名 { 
类 体 





} 


下 面 对 其 中 各 项 做 说 明 。 

@ ”权限 修饰 符 ， 可 以 忽略 ， 也 可 以 在 public、protected、private 中 选择 一 个 。 

@ class: 创建 类 的 关键 字 。 

@ ”类 名 : 所 创建 类 的 名 称 ， 必 须 写 在 class 关键 字 之 后 ， 在 类 名 之 后 必须 加 一 对 花 
括号 { }。 

@ 类 体 : 是 类 的 成 员 ， 类 体 必 须 放 在 类 名 之 后 的 花 括 号 “{” 和 “}” 之 间 。 

例如 ， 创 建 一 个 connect_ mysql 类 ， 代 码 如 下 : 

<?php 
class connect mysql{ 


} 
> 


13.2.2 ”属性 和 方法 的 定义 


1. 属性 
属性 就 是 在 类 体 中 定义 的 变量 ， 用 于 保存 和 设置 参数 。 属 性 的 声明 必须 有 关键 字 来 修 
饰 ， 如 public、protected、private 等 ， 如 果 不 需 要 特定 的 含义 ， 可 以 使 用 var 关键 字 来 修饰 。 
例如 ， 在 类 connect_ mysql 的 类 中 声明 属性 ， 代 码 如 下 : 
<?php 
class connect mysql{ 
public $host; 
public $user; 
public S$password; 
public $dbname; 
public $conn; 


} 
Ss 


2. 方法 

方法 就 是 在 类 体 中 定义 的 函数 。 方 法 的 声明 可 以 用 关键 字 来 修饰 ， 以 此 来 控制 方法 的 
权限 。 

例如 ， 在 类 connect_mysql 中 声明 方法 ， 代 码 如 下 : 


Class connect mysqlt{ 
function connectDB(){ 
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} 
function getconnID(){ 
} 

} 


在 类 中 ， 属 性 和 方法 的 声明 可 以 根据 具体 情况 来 确定 ， 不 是 必须 同时 存在 的 。 
13.2.3 ”类 的 实例 化 


类 在 程序 中 不 能 直接 使 用 ， 必 须 实例 化 后 才能 使 用 。 对 象 是 类 实例 化 的 产物 ， 是 面向 
对 象 程序 的 最 终 操作 者 。 类 实例 化 的 语法 格式 如 下 
$ 变 量 名 =new 类 名 称 ( [参数 ] ) ; 
下 面 对 此 语法 中 的 各 项 做 说 明 。 
$ 变 量 名 : 是 类 实例 化 后 返回 的 对 象 名 称 ， 用 于 引用 类 中 的 方法 。 
new: 关键 字 ， 表 明 要 创建 一 个 新 的 对 象 。 
类 名 称 : 表示 新 对 象 的 类 型 。 
参数 : 可 选 。 指 定 类 的 构造 方法 ， 用 于 初始 化 对 象 的 值 。 如 果 类 中 没有 定义 构造 
方法 ，PHP 会 自动 创建 一 个 不 带 参 数 的 默认 构造 方法 。 
例如 ， 对 类 connect_mysql 进行 实例 化 ， 代 码 如 下 
<?php 


$connl=new connect_ mysql (); 
$conn2=new connect _ mysql (); 

















?> 


13.2.4 ”访问 类 中 的 成 员 


访问 类 中 的 成 员 是 指 访问 类 的 属性 和 方法 。 访 问 的 方法 与 访问 数组 元 素 的 方法 类 似 ， 
需要 借助 于 运算 符号 “->”， 通 过 对 对 象 的 引用 来 访问 类 的 属性 和 方法 。 访 问 类 的 属性 和 
方法 的 语法 格式 如 下 : 

$ 变 量 名 =new 类 名 称 [参数 ] ; 

$ 变 量 名 -> 属性 = 值 ; 

$ 变 量 名 -> 属性 ; 

$ 变 量 名 -> 方法 ; 





13.2.5 ”特殊 的 访问 方法 一 一 $this 和 “::” 


1. $this 
Sthis 是 一 个 特殊 的 应 用 对 象 的 方法 ， 它 存在 于 类 的 每 个 方法 中 。 方 法 属于 哪个 对 象 
Sthis 引用 就 代表 哪个 对 象 ， 其 作用 就 是 专门 完成 对 象 内 部 成 员 之 间 的 访问 。 
2. 操作 符 “2 
Sthis 引用 只 能 在 类 的 内 部 使 用 ， 而 操作 符 “::” 可 以 在 没有 声明 任何 实例 的 情况 下 访 
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问 类 的 属性 和 方法 。 操 作 符 “::” 的 语法 格式 如 下 : 
关键 字 : :变量 名 /常量 名 /方法 名 


这 里 关键 字 分 为 parent、self 和 类 名 三 种 。 

@ parent: 可 以 调用 父 类 中 的 成 员 变 量 、 成 员 方 法 和 常量 。 
@ self: 可 以 调用 当前 类 中 的 静态 成 员 和 常量 。 

@ 类 名 称 : 可 以 调用 本 类 中 的 变量 、 常 量 和 方法 。 


13.2.6 ”构造 方法 


构造 方法 是 对 象 构造 完成 后 第 一 个 被 对 象 自动 调用 的 方法 ， 它 存在 于 每 个 声明 的 类 
中 ， 如 果 类 中 没有 直接 声明 构造 方法 ， 则 类 中 会 默认 生成 一 个 没有 任何 参数 、 内 容 为 空 的 
构造 方法 。 

在 PHP5 之 前 的 版 本 中 ， 构 造 方法 的 名 称 必须 与 类 的 名 称 相 同 ， 在 PHP5 之 后 ， 构 造 
方法 的 名 称 必须 以 两 个 下 画 线 开始 的 ， 即 __construct()。 但 在 目前 的 PHP7 系统 中 ， 之 前 的 
构造 方法 的 命名 方式 依然 可 用 。 

声明 构造 方法 的 语法 格式 如 下 : 

function _ construct([mixed args[,..]]){ 

// 方 法 体 

} 

每 个 类 中 只 能 声明 一 个 构造 方法 。 如 果 构造 方法 没有 传 入 参数 ， 则 使 用 默认 参数 为 变 
量 进行 初始 化 。 


13.2.7” 析 构 方法 


析 构 方法 的 作用 与 构造 方法 的 作用 正好 相反 。 析 构 方 法 是 对 象 被 销毁 之 前 最 后 一 个 被 
对 象 自动 调用 的 方法 ， 实 现在 销毁 一 个 对 象 之 前 完成 一 些 特定 的 操作 ， 如 关闭 文件 、 释 放 
内 存 等 。 
析 构 方法 的 命名 是 以 两 个 下 画 线 开 始 ， 即 __destructD。 析 构 方法 没有 参数 ， 其 声明 的 
语法 格式 如 下 : 
function __destruct(){ 
// 方 法 体 
| 
PHP 系统 有 一 种 “垃圾 回收 ”机 制 ， 它 可 以 自动 清除 不 再 使 用 的 对 象 ， 释 放 内 存 。 而 
析 构 方法 的 执行 先 于 PHP 的 这 种 “垃圾 回收 ”程序 ， 在 PHP 中 属于 可 选 内 容 。 
【实例 13-1】 创 建 类 ， 并 对 类 实例 化 ， 访 问 类 中 的 属性 和 方法 。 
<?php 
header ("Content-Type:text/html;charset=gb2312"); 
class connect mysql{ 


public $host; 
public $user; 
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public $password; 
public $dbname; 
public $conn; 
public function _ construct ($host, $user, $password, $dbname) { 
$this->host=$host; 
$this->user=$user; 
$this->password=$password; 
$this->dbname=$dbname; 
Sthis->connect (); 
+ 
public function connect(){ 
$this->conn=mysqli_connect ($this->host, $this->user, $this-— 
>password, $this->dbname); 
mysqli_query ($this->conn,"set names gb2312"); 
} 
public function GetId(){ 
echo "mysql 服务 器 的 用 户 名 :" .Sthis->user, "<br/>"; 
echo "Mysql 服务 器 密码 :" .Sthis->password, "<br/>"; 
} 
} 
$result =new connect mysql ("localhost","root","","online c"); 
$result->GetId(); 
Ts 


程序 运行 结果 如 图 13-1 所 示 。 
加 Yocslhost /oanple_ 13-: x 


© DD localhost 


Jiysql 服 务 器 的 用 户 名 :root 


Mysql 服务 器 的 密码 : 





13-1 实例 13-1 运行 结果 


13.3 类 的 封装 


类 的 封装 是 指 将 类 的 属性 和 方法 结合 成 一 个 独立 的 相同 单位 ， 并 尽 可 能 隐藏 对 象 的 内 
容 细节 。 类 封装 的 目的 就 是 确保 类 以 外 的 部 分 不 能 随意 存 取 类 的 属性 和 方法 ， 避 免 外 部 错 


误 对 类 的 内 部 数据 的 影响 。 


类 的 封装 是 通过 关键 字 public、private、protected、static 和 final 来 实现 的 。 


13.3.1 ”public 公共 成 员 


public 就 是 可 以 公开 、 没 有 必要 隐藏 的 数据 信息 ， 可 以 在 程序 的 任何 地 方 被 其 他 的 类 
和 对 象 引用 。 子 类 可 以 继承 和 使 用 父 类 中 所 有 的 公共 成 员 。 若 类 中 的 方法 没有 写 关 键 字 ， 


默认 是 public。 
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<?php 
header ("Content-Type:text/html;charset=gb2312"); 
class colort{ 
public $name=" 红 色 "; 
} 
$my_color=new color; 
$my_color->name=" 蓝 色 "; 
echo "所 选 颜色 : ", $my_color->name; 
?> 


程序 运行 结果 如 图 13-2 所 示 。 


园 1ecalhost /erasple 13- x 
4 © Dlocalhost 
所 选 颜色 ， 蓝 色 





13-2 ”实例 13-2 运行 结果 


13.3.2 private 私有 成 员 


被 private 修饰 的 变量 和 方法 ， 只 能 在 所 属 类 的 内 部 被 调用 和 修改 ， 不 能 在 类 的 外 部 被 
访问 ， 子 类 也 不 能 进行 访问 。 
【实例 13-3】 访 问 类 的 私有 属性 。 
<?php 
header ("Content-Type:text/html;charset=gb2312"); 
class color{ 
private $name=" 红 色 "; 
} 
$my_color=new color; 
$my_color->name=" 蓝 色 "; 
echo "所 选 颜色 : ", $my_color->name; 
?> 


由 于 类 color 中 的 属性 $name 为 私有 的 ， 所 以 在 类 的 外 部 是 没有 权限 访问 Sname 的 ， 因 
而 程序 运行 会 出 现 错误 提示 ， 如 图 13-3 所 示 。 





国 1ocalhost/eranple_13-: 


€ 3 CC Dlocalhost/exanpl 


Fatal error: Uncaught Error: Cannot access private 
property color::$name in 
C:\xampp\htdocs\example_13-3. php:7 Stack trace: #0 
{main] throm in C:\xampp\htdocs\example_13-3.php 
on line 7 





13-3 ”实例 13-3 运行 结果 
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13.3.3 ”protected 保护 成 员 


被 protected 修饰 的 属性 和 方法 ， 只 能 在 本 类 及 其 子 类 中 被 调用 ， 在 程序 的 其 他 地 方 则 
不 可 以 被 调用 。 
【实例 13-4】 访 问 类 的 protected 属性 。 


<?php 
header ("Content-Type:text/html;charset=gb2312"); 
class color{ 
Protected $name=" 红 色 "; 
public function show_color(){ 
echo "所 选 颜色 : "，$this->name; 
$my_color=new color; 
$my_color->show_color (); 
echo $my_color->name; 
区 


在 类 color 的 内 部 ， 方 法 show_color0 可 以 访问 protected 属性 Sname; 而 在 类 的 外 部 ， 
则 没有 权限 访问 类 color 的 protected 属性 Sname。 运 行 结果 如 图 13-4 所 示 。 


€ © DD localhost/exanple 
所 选 颜色 ,红色 


Fatal error: Uncaught Error: Cannot access 
protected property color::$name in 
C:\xampp\htdocs\example_13-4. php:11 Stack trace: 
#0 [mainj throm in C:\xampp\htdocs\example_13- 
4.php on line 11 





图 13-4 ”实例 13-4 运行 结果 
13.3.4 ”static 静态 成 员 
通过 static 关键 字 修 饰 的 属性 和 方法 被 称 为 静态 属性 和 静态 方法 。 静 态 属性 和 静态 方 
法 不 需要 在 被 类 实例 化 的 情况 下 就 可 以 直接 使 用 。 
1. 静态 属性 


静态 属性 属于 类 本 身 而 不 属于 类 的 任何 实例 。 它 相当 于 存储 在 类 中 的 全 局 变量 ， 可 以 
在 程序 的 任意 位 置 通过 类 来 访问 。 静 态 属性 访问 的 语法 格式 如 下 : 
类 名 称 : : $ 静 态 属性 名 称 


其 中 的 符号 “::” 称 作 范 围 解析 操作 符 ， 用 于 访问 、 用 盖 静态 属性 、 静 态 方 法 和 常量 。 
如 果 是 在 类 的 内 部 引用 静态 属性 ， 则 需要 在 静态 属性 前 加 上 操作 符 “self::”。 


2. 静态 方法 
静态 方法 同 静 态 属性 一 样 ， 不 受 任何 对 象 的 限制 ， 不 需要 通过 类 的 实例 化 就 可 以 被 直 
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接 引 用 。 静 态 方法 访问 的 语法 格式 如 下 : 
类 名 称 : : $ 静 态 方法 名 称 ( [参数 1, 参数 2,…] ) 
如 果 是 在 类 的 内 部 引用 静态 方法 ， 也 要 在 静态 方法 前 加 上 操作 符 “self:”。 
[对 提示 : 在 静态 方法 中 ， 只 能 调用 静态 变量 ， 而 不 能 调用 普通 变量 ; 而 在 普通 方法 
中 则 可 以 调用 静态 变量 。 


【实例 13-5】 访问 类 的 静态 属性 。 


<?php 
header ("Content-Type:text/html;charset=gb2312"); 
class count number{ 
static $n=0; // 定 义 静态 变量 
public function count(){ 
echo "n= 第 ", self::$n,"<br/>";  ”// 输 出 静态 变量 的 值 
self::$n++; // 静 态 变量 自 增 运算 
} 
} 
echo "第 一 次 实例 化 : <br/>"; 
$my_click=new count_ number; 
$my_click->count (); 
$my_click->count (); 
echo "第 二 次 实例 化 ，<br/>"; 
$my_click=new count_number; 
$my_click->count (); 
$my_click->count (); 
> 


程序 运行 结果 如 图 13-5 所 示 。 


localhost/example_13- 


第 一 次 实例 化 ， 
m0 


ml 
第 二 次 实例 化 ， 
m2 


m3 





图 13-5 ”实例 13-5 运行 结果 


13.3.5 final 最 终 成 员 


如 果 有 类 被 final 修饰 ， 说 明 该 类 不 可 以 被 继承 ， 也 不 能 有 子 类 。 若 有 方法 被 final 修 
饰 ， 说 明 该 方法 在 子 类 中 不 可 以 重 写 ， 也 不 可 以 被 覆盖 。 
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13.4 ”类 的 继承 与 重 载 


13.4.1 类 的 继承 


类 的 继承 能 够 使 一 个 类 继承 并 拥有 另 一 个 已 存在 类 的 属性 和 方法 ， 其 中 被 继承 的 类 称 
为 父 类 ， 继 承 的 类 称 为 子 类 。 子 类 不 仅 可 以 拥有 父 类 所 有 的 属性 和 方法 ， 还 可 以 拥有 自己 
的 属性 和 方法 。 在 PHP 中 ， 每 个 子 类 只 能 有 一 个 父 类 ， 而 一 个 父 类 可 以 有 多 个 子 类 。 

在 PHP 中 ， 类 的 继承 是 通过 关键 字 extends 实现 的 ， 其 语法 格式 如 下 : 


class 子 类 名 称 extends 父 类 名 称 { 
-… // 子 类 的 属性 
function 方法 名 称 () { // 子 类 的 方法 


} 
} 


【实例 13-6】 创 建 一 个 父 类 及 其 子 类 。 


<?php 
header ("Content-Type:text/html;charset=gb2312"); 
class people { 

public $name; 

public $age; 


} 
class student extends people {  // 声 明子 类 


function get info() { 
echo $this->name, $this->age, "<br/>"; 
} 


} 
$p = new people; // 父 类 实例 化 


Sp->name = "小 明 "7 


$p->age = 18; 
echo $p->name, $p->age, "<br/>"; // 输 出 父 类 的 属性 值 


$x = new student; // 子 类 实例 化 
$x->name = "大 鹏 "7 

$x->age = 28; 

$x->get_info(); // 调 用 子 类 的 方法 


2> 
程序 运行 结果 如 图 13-6 所 示 。 


localhost/example_13-6. php 


小 明 18 


大 网 28 





13-6 “实例 13-6 运行 结果 
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通过 “parent::” 关 键 字 也 可 以 在 子 类 中 调用 父 类 的 方法 ， 其 语法 格式 如 下 : 
parent : : 父 类 的 方法 (参数 ) 
【实例 13-7】 通 过 关键 字 “parent::” 访 问 父 类 的 方法 。 


<?php 
header ("Content-Type:text/html;charset=gb2312"); 
class people { 
public $name; 
public $age; 
public function show_ info(){ 
echo $this->name, $this->age, "<br/>"; 
上 














class student extends people { // 声 明子 类 
function get info() { 
parent: :show_info(); // 调 用 父 类 的 方法 
} 
} 
$p = new people; // 父 类 实例 化 
$p->name = "小 明 "7 
$p->age = 18; 
echo $p->name, $p->age, "<br/>"; // 输 出 父 类 的 属性 值 
$x = new student; // 子 类 实例 化 


$x->name = "大 鹏 "7 

$x->age = 28; 

$x->get_info(); // 调 用 子 类 的 方法 
> 


程序 运行 结果 与 实例 13-6 的 运行 结果 相同 。 
号 提示 :， 类 的 继承 是 单 向 性 的 ， 即 如 果 类 也 继承 了 类 A， 则 类 A 不 可 以 再 继承 类 B 了. 


13.4.2 ”类 的 重 载 


如 果 在 父 类 中 已 经 定义 了 某 属 性 或 方法 ， 然 后 在 子 类 中 定义 与 父 类 同名 的 属性 和 方 
法 ， 这 就 是 类 的 重 载 。 利 用 类 的 重 载 ， 可 以 重 写 父 类 中 指定 方法 所 实现 的 功能 。 
【实例 13-8】 利 用 类 的 重 载 ， 调 用 父 类 的 方法 。 


<?php 
header ("Content-Type:text/html;charset=gb2312"); 
class people { 
public $name; 
public $age; 
public function show info(){ 
echo $this->name, $this->age,"<br/>"; 
} 
} 
class student extends people { // 声 明子 类 
function show info() { 
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echo "修改 后 的 年 龄 : ", $this->age+15; 
} 
} 
$x = new student; // 子 类 实例 化 
Sx->name = "大 鹏 "; 
$x->age = 28; 
$x->show_info(); // 调 用 子 类 的 方法 
> 


程序 运行 结果 如 图 13-7 所 示 。 


€ DIC)|D localhost/exanple_13-8. phr 
修改 后 的 年 龄 ，43 





13-7 ”实例 13-8 运行 结果 


[对 提示 : 类 重 载 的 关键 之 处 在 于 ， 可 以 在 子 类 中 创建 与 父 类 相同 的 方法 ， 包 括 方法 
名 称 、 参 数 及 其 返回 值 。 


13.5 接 口 
13.5.1 接口 的 声明 


在 PHP 中， 类 的 继承 是 单 向 性 的 ， 若 想 实现 类 的 多 重 继承 ， 就 要 使 用 接口 了 。 
接口 是 通过 关键 字 interface 来 声明 的 ， 接 口中 声明 的 方法 必须 是 抽象 方法 ， 但 接口 中 
不 能 声明 属性 ， 只 能 使 用 const 关键 字 声 明 为 常量 的 属性 ， 而 且 接口 中 所 有 成 员 都 要 具有 
public 的 访问 权限 。 接 口 声明 的 语法 格式 如 下 : 
interface 接口 名 称 { 
// 常 量 属性 
// 抽 象 方法 
上 
接口 不 能 进行 实例 化 操作 ， 需 要 通过 子 类 来 进行 访问 ， 但 是 接口 可 以 直接 使 用 接口 名 
称 在 接口 外 部 获取 常量 及 属性 的 值 。 


13.5.2 ”接口 的 应 用 


1 于 接口 不 能 进行 实例 化 的 操作 ， 因 此 访问 接口 就 要 借助 于 子 类 。 在 子 类 中 继承 接 
口 要 使 用 关键 字 implements， 如 果 要 实现 多 个 接口 的 继承 ， 则 每 个 接口 之 间 要 用 逗号 “,” 
连接 。 
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【实例 13-9】 访 问 接口 。 


<?php 
header ("Content-Type:text/html;charset=gb2312"); 
interface person{ // 声 明 接口 person 


public function person info(); 
人 
interface salaryf // 声 明 接口 salary 
public function salary info(); 
} 
class my_info implements person,salary{  // 声 明子 类 
public function person info(){ 
echo "我 是 公务 员 ", "<br/>"; 
;» 
public function salary_ info(){ 
echo "我 的 薪水 是 10000 元 "; 
' 
Sme =new my_info; 
$me->person_info(); 
$me->salary_info(); 
?> 


程序 运行 结果 如 图 13-8 所 示 。 


固 :jeeaahoat/ezazple 13-5 x 


© BD localhost/exanple 
我 是 公务 员 


我 的 薪水 是 10000 元 





图 13-8 实例 13-9 运行 结果 
13.6 ”综合 实 训 案 例 
本 节 主 要 介绍 利用 类 封装 一 个 连接 数据 库 的 类 。 


1. 分 析 
定义 一 个 析 构 函数 ， 将 外 部 传 入 的 参数 变量 转换 为 类 的 内 部 变量 ， 并 在 类 实例 化 的 时 
候 调 用 connect() 方 法 。 


创建 connect0 方 法 ， 其 功能 是 利用 mysqli_connect0 函 数 连接 MySQL 数据 库 。 
2. 程序 代码 
<?php 


class mysql_connect{ 
private $host; 
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private $user; 
private $pwd; 
private $conn; 
private $dbname; 
public function _construct ($host, $user, $pwd, $conn, $dbname) { 
$this->host=$host; 
$this->user=$user; 
$this->pwd=$pwd; 
$this->connt=$conn; 
$this->dbname=$dbname; 
} 
public function connect(){ 
$this->conn=mysqli_connect ($this->host, $this->user, $this->pwd, Sthis->dbname) 7 
} 
} 
$mysql=new mysql_connect ("localhost", "root","", "student"); 
人 


本 章 小 结 


本 章 详细 介绍 了 PHP 面向 对 象 的 编程 方式 和 方法 。 面 向 对 象 就 是 将 要 处 理 的 问题 抽象 
为 对 象 ， 通 过 对 象 的 属性 和 方法 来 解决 对 象 的 实际 问题 。 

类 是 属性 和 方法 的 集合 ， 是 面向 对 象 编程 方式 的 核心 和 基础 ， 对 象 是 类 的 实例 化 ， 类 
可 以 封装 、 继 承 和 重 载 。 方 法 是 指 在 类 中 声明 的 函数 ， 一 个 类 中 可 以 声明 多 个 函数 。 


习 题 
1. 已 知 一 个 类 car， 请 实例 化 : 名 称 为 “宝马 ”， 颜 色 为 “黑色 ”， 长 度 为 5， 并 输 
出 信息 。 


class cart{ 
public $name; 
public $color; 
public $size; 
} 


2. 已 知 一 个 类 pen， 请 实例 化 : 名 称 为 “英雄 牌 ”， 左 色 为 “黑色 ”， 并 调用 类 中 的 
方法 输出 信息 。 


class pent{ 

public $name; 

public $color; 

public function attri($p_name, $p_color){ 
$this->name=$p_name; 
$this->color=$p_color; 

} 

public function print attri($p name, $p_color){ 
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echo "名 称 : "，, $this->name; 
echo "颜色 : ", $this->color; 
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本 章 要 点 

@@ ”PDO 连接 数据 库 的 方法 

@ 在 PDO 中 执行 SQL 语句 的 方法 
学 习 目 标 

@ 掌握 PDO 连接 数据 库 的 方法 

@ 掌握 在 PDO 中 执行 SQL 语句 的 方法 


14.1 PDO 概述 


14.1.1 PDO 的 概念 及 特点 
1. PDO 的 概念 


PDO 是 PHP Data Object(PHP 数据 对 象 ) 的 简称 ， 是 PHP 5.1 之 后 发 布 的 一 个 全 新 的 数 
据 库 连接 层 ， 它 支持 目前 流行 的 绝 大 多 数 数据 库 ， 例 如 MySQL、MS SQL Server、 
Oracle、Sybase 等 。PDO 出 现 后 ，PHP 程序 连接 数据 库 就 不 再 使 用 mysqli_* 函 数 、oci_* 函 
数 或 者 mssql_* 函 数 了 ， 只 需要 使 用 PDO 接口 中 的 方法 就 可 轻松 地 连接 数据 库 ， 而 且 只 需 
要 修改 PDO 的 DSN( 数 据 源 名 称 ) 就 可 以 连接 不 同类 型 的 数据 库 。 

2. PDO 的 特点 

PDO 的 作用 就 是 统一 各 种 数据 库 的 访问 接口 ， 这 样 可 以 轻松 地 与 各 种 数据 库 进 行 交 
互 ， 使 得 PHP 操作 各 种 不 同类 型 的 数据 库 更 加 方便 和 高 效 。 

PDO 扩展 是 模块 化 的 ， 用 户 在 运行 时 ， 只 需要 为 数据 库 加 载 驱动 程序 即 可 ， 不 需要 种 
新 编译 和 安装 PHP 系统 。 


14.1.2 ”PDO 的 配置 





十 





PDO 是 随 着 PHP 系统 一 起 发 行 的 ， 默 认 情 况 下 ，PDO 在 PHP 系统 中 为 开启 状态 。 如 
果 要 启用 对 某 个 数据 库 驱 动 程序 的 支持 ， 就 要 打开 php.ini 文件 进行 相应 的 配置 。PDO 的 
配置 选项 如 图 14-1 所 示 。 


居 php_ini - 记事 本 
文件 下 编辑 开 ) 格式 0) 查看 WD 帮助 中 





extension=php_pdo_sqlite.dll 
extension=php_pdo_mysql.dll 
;extension=php_pdo firebird.dll 


;extension=php_pdo_oci.dIl 
;extension=php_pdo_odbc.dll 
;extension=php_pdo_pgsql.dll 





14-1 PDO 配置 选项 
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号 提示 :， 。 需要 加 载 PDO 的 其 他 选项 ， 只 需 去 除 该 选项 左 侧 的 分 号 “; ” 即 可 。 
e@ ”PDO 的 选项 加 载 后， 保存 php.ini 文件 ， 重 新 启动 Apache 服务 器 后 
PDO 选项 才 会 生效 。 
要 检测 PHP 系统 中 PDO 是 否 已 经 启动 ， 可 以 编写 一 个 PHP 程序 ， 写 入 语句 : 


<?php 
phpinfo(); 
ES 


该 PHP 程序 文件 启动 后 ， 若 能 找到 PDO 的 信息 内 容 ， 就 说 明 PDO 已 经 启动 ， 如 
14-2 所 示 。 


加 papin:e 加 
和 © |D localhost/check pdc. php 


ET 





pdo_mysql 


| wmlni 5 .12-dey - 20150407 - $1d: Tef2f3090V1490nl heatTohsT esSaeal cde pss $ 





pdo_sqlitc 
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14.2 ”PDO 连接 数据 库 
在 PDO 中 ， 要 建立 与 数据 库 的 连接 ， 需 要 实例 化 PDO 的 构造 函数 。PDO 构造 函数 的 
语法 格式 如 下 : 
construct (string dsn, string username, string password,array driver_options) 
PDO 构造 函数 的 参数 说 明 如 表 14-1 所 示 。 
表 14-1 PDO 构造 函数 的 参数 说 明 





参 数 含义 
dsn 规定 PDO 的 数据 源 名 ， 包 括 主机 名 (地 址 )、 端 口号 和 数据 库 名 称 
username 可 选 。 规 定 PDO 连接 数据 库 的 用 户 名 
password 可 选 。 规 定 PDO 连接 数据 库 的 密码 








driver_options 


可 选 。 规 定 连 接 数 据 库 的 其 他 选项 。 具 体内 容 参考 PDO 预定 义 常量 的 内 容 
【实例 14-1】 使 用 PDO 连接 MySQL 数据 库 。 


<?php 
header ("Content-Type:text/html;charset=gb2312"); 
$db_name="student"; / /数据库 名 称 
$user="root"; / /连接 数据 库 的 用 户 名 
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S$password=""; / /连接 数据 库 的 密码 
$host="localhost"; / /数据 库 服 务 器 地 址 
$dsn="mysql:host=$host;dbname=$db_name"; // 数 据 源 名 称 
tryt{ 
$pdo=new PDO($dsn, $user,$password); // 实 例 化 对 象 
echo "PDO 连接 数据 库 成 功 ! "; 
}catch (Exception $e) // 捕 捉 错误 信息 
{ 
echo $e->getMessage(); 
， 
> 


为 了 编程 方便 ， 可 以 将 PDO 连接 数据 库 的 代码 编辑 成 一 个 独立 的 PHP 程序 文件 (如 
pdo_connect.php)， 需 要 使 用 PDO 连接 数据 库 的 时 候 ， 可 以 通过 include0 或 include_once() 
语句 调用 该 程序 文件 。 程 序 文件 pdo_conncet.php 程序 文件 代码 如 下 : 


<?php 
$db_name="student"; // 数 据 库 名 称 
$user="root"; // 连 接 数 据 库 的 用 户 名 
$password=""; // 连 接 数 据 库 的 密码 
$host="localhost"; // 数 据 库 服务 器 地 址 
$dsn="mysql:host=$host;dbname=$db_name"; // 数 据 源 名 称 
Yt 


$pdo=new PDO($dsn, $user,$password); // 实 例 化 对 象 
$pdo->query ("set names gb2312"); 
}catch (Exception $e) // 捕 捉 错误 信息 
{ 
echo $e->getMessage(); 
} 
2 


14.3 在 PDO 中 执行 SQL 语句 


PDO 连接 数据 库 成 功 后 ， 就 可 以 执行 SQL 语句 操作 数据 表 了 。 在 PDO 中 执行 SQL 
语句 主要 采用 三 种 方法 : exec() 方 法 、query() 方 法 和 预 处 理 语句 prepare() 及 execute()。 


14.3.1 exec() 方 法 


exec() 方 法 执行 后 返回 受 影响 记录 的 行 数 ， 其 语法 格式 如 下 : 


int PDO:exec(string statement) 





参数 说 明 如 表 14-2 所 示 。 
表 14-2 exec() 方 法 的 参数 说 明 
参 数 含义 





statement 规定 要 执行 的 SQL 语句 。SQL 语句 通常 指 INSERT、DELETE 和 UPDATE 语句 
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【实例 14-2】 使 用 exec0 方 法 执行 删除 操作 。 


假设 数据 库 student 包含 数据 表 score， 数 据 表 的 记录 如 表 14-3 所 示 。 使 用 exec0 方 
法 ， 删 除 其 中 cj 字段 值 小 于 60 的 记录 。 








nn 











表 14-3 表 score 的 记录 情况 


xh j kc 
150212101 | 方 波 材料 2015 高 等 数学 
150412312 Ei 文法 2015 








150313223 
150112224 








<?php 
header ("Content-Type:text/html;charset=gb2312"); 
include_once ("pdo_connect .php"); 


$sql="delete from score where cj<60"; // 要 执行 的 SQL 语句 
tryt{ 
$rows=$pdo->exec ($sq1); // 执 行 SQL 语句 
echo " 共 删 除 记 录 : "，, $rows; 
}catch (Exception $e) 
{ 
echo $e->getMessage(); 
} 
?> 


14.3.2 query() 方 法 


query0) 方 法 执行 后 返回 查询 后 的 结果 集 ， 其 语法 格式 如 下 : 
PDOStatement PDO:query (string statement) 
参数 说 明 如 表 14-4 所 示 。 
表 14-4 query() 方 法 的 参数 说 明 
参 数 含义 








statement 规定 要 执行 的 SQL 语句 。SQL 语句 通常 指 SELECT 语句 
【实例 14-3】 使 用 query0 方 法 执行 查询 操作 。 
<?php 


header ("Content-Type:text/html;charset=gb2312"); 
include once ("pdo_connect .php"); 
$sql="select * from score where cj>=60"; 
try{ 
$result=$pdo->query ($sq1); 
foreach ($result as S$r) 
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{ 
echo S$rf"xh"]," ,S$rf"xm"]," ,Srf"bj"]," ", Srf"kc"]," 
", S$rf"cj"], "<br/>"; 
} 
}catch (Exception $e) 
{ 
echo $e->getMessage(); 

} 

2 


程序 运行 结果 如 图 14-3 所 示 。 


localhost/pdo. php x 


< © D localhost 


150212101 方 波 材料 2015 高 等 数学 92 
150313223 于 文 华 会 计 2015 社会 学 67 





图 14-3 ”实例 14-3 运行 结果 
[ 缉 提 示 : 由 于 PHP 默认 的 字符 集 为 UTF-8， 显 示 中 文 记 录 时 浏览 器 页 面 上 经 常会 出 
现 乱 码 。 因 此 可 以 使 用 语句 $pdo->query ("set names gb2312") ;将 字符 集 

转换 为 简体 中 文字 符 集 ， 以 解决 乱码 的 现象 。 


14.3.3” 预 处 理 语句 prepare() 和 execute() 


prepare() 方 法 先 做 查询 的 准备 工作 ， 然 后 调用 execute() 方 法 执行 查询 ， 并 且 还 可 以 通 
过 bindParam() 方 法 来 绑 定 参数 提供 给 execute() 方 法 。prepare() 方 法 和 execute() 方 法 的 语法 
格式 如 下 : 


PDOStatement PDO:Prepare (string statement,array driver_option) 
bool PDOStatement : :execute (array input prarameters) 


prepare() 方 法 的 参数 说 明 如 表 14-5 所 示 。 
表 14-5 prepare() 方 法 的 参数 说 明 
含义 
规定 要 执行 的 操作 语句 
可 选 。 规 定 连 接 数 据 库 的 其 他 选项 ， 具 体内 容 参 考 PDO 预定 义 常量 内 容 


statement 





driver_options 
execute() 方 法 的 参数 说 明 如 表 14-6 所 示 。 
表 14-6 ”execute() 方 法 的 参数 说 明 





含义 
可 选 。 规 定 prepare0 方 法 要 执行 SQL 语句 的 参数 


参 数 


input_parameters 
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【实例 14-4】 使 用 prepare() 方 法 和 execute0 方 法 添加 记录 。 


<?php 
header ("Content-Type:text/html;charset=gb2312"); 
include once ("pdo_connect. php"); 
$query="insert into score set 
xh=:s_xh, xm=:5_xm,bj=:s_bj, kc=:s_kc,cj=:s_cj"; 
try{ 
$result=$pdo->prepare ($query); 
$result->execute (array (':s_xh'=>'140213023',' :s_xm'=>' 钱 文 刚 
"bj'=>' 金 融 2014',":5_kc'=>" 西 方 经 济 学 '"。 :5 cj'=>67)); 
echo "记录 成 功 加 入 ! "; 
}catch (Exception $e) 
{ 
echo $e->getMessage(); 


?> 


【实例 14-5】 使 用 prepare() 方 法 和 execute() 方 法 查询 记录 。 


<?php 
header ("Content-Type:text/html;charset=gb2312"); 
include_once ("pdo_connect .php"); 
$query="select * from score where cj>=:s_cj"; 
try{ 
$result=$pdo->prepare ($query); 
$result->execute (array(':s_cj'=>60)); 
while($r=$result->fetch (PDO: :FETCH_ASSOC)) 
{ 
echo Sri 写本 关 
echor srl uml 
ochol Sr[ DI} 有 
echo SEP ke ms 
acho STinelml ebx 
} 
}catch (Exception $e) 


echo $e->getMessage(); 
?> 


程序 运行 结果 如 图 14-4 所 示 。 


国 1ocalhost/ezazple_14-5 x 


€ 3 CC Dlocalhost/es 


150212101 方 波 材料 2015 高 等 数学 92 
150313223 于 文 华 会 计 2015 社会 学 67 
140213023 钱 文 刚 金融 2014 西方 经 济 学 67 
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[于 提示 : 。 提供 给 预 处 理 处 理 语句 的 参数 左 端 要 带 冒 号 “:”， 而 且 不 需要 用 引号 括 
起 来 。 如 果 prepare0 执 行 的 SQL 语句 没有 参数 ， 则 的 括 生 应 为 空 。 
@ 如 果 在 PHP 程序 中 只 执行 一 次 查询 ， 使 用 PDO->query0 是 较 好 的 选择 ; 
如 果 要 多 次 执行 SQL 语句 ， 最 好 使 用 prepare() 和 execute()， 这 两 个 方法 
既 可 以 预防 SQL 注入 攻击 ， 又 占用 较 少 系统 资源 。 


14.4 PDO 获取 结果 集 


当 使 用 PDO->query0) 或 使 用 prepare0 和 execute() 查 询 记 录 时 ， 会 得 到 返回 的 结果 集 ， 
常用 的 获取 结果 集 的 方法 有 :，fetch0、fetchAll0 和 fetchColumn()。 


14.4.1 ”fetch() 方 法 


fetch0 方 法 获取 结果 集中 的 下 一 行 ， 其 语法 格式 如 下 : 


mixed PDOStatement::fetchl(int fetch_ style,int cursor orientation,int 
cursor_offset) 


fetch( 方 法 的 参数 说 明 如 表 14-7 所 示 。 
表 14-7 ”fetch() 方 法 的 参数 说 明 


参 数 
fetch_style 


含义 
可 选 。 规 定 结果 集 的 返回 方式 ， 具 体 值 如 表 14-8 所 示 
可 选 。 规 定 PDOStatement 对 象 的 一 个 浮动 游标 ， 可 用 于 获取 指定 的 一 行 


cursor_orientation 




















cursor_offset 可 选 。 规 定 游标 的 偏 移 量 
表 14-8 ”fetch_style() 可 选 值 
一 和 一 

PDO::FETCH ASSOC 关联 数组 形式 
PDO::FETCH NUM 数字 索引 数组 形式 
PDO::FETCH BOTH 两 者 数组 形式 都 有 ， 为 默认 值 
PDO::FETCH_OBJ 按照 对 象 的 形式 

以 布尔 值 的 形式 返回 结果 ， 同 时 将 获取 的 列 的 值 赋 给 bindParam0 方 法 
PDO::FETCH_BOUND 

中 指定 的 变量 
PDO::FETCH_LAZY 以 关联 数组 、 数 字 索 引 数组 对 象 和 对 象 三 种 形式 返回 结果 

【实例 14-6】 使 用 fetch0 方 法 获取 结果 集 的 数据 。 


<?php 
header ("Content-Type:text/html;charset=gb2312"); 
include once ("pdo_connect .php"); 
$query="select * from Sscore ™; 
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tryt{ 
$result=$pdo->prepare ($query); 
$result->execute(); 
while($r=$result->fetch (PDO: :FETCH_OBJ)) 
{ 
echo $r->xh," " 
echo $r->xm," 
echo $r->bj," " 
echo r=>ker™™ 
echo $r->cj,"<br/>"; 
} 
}catch (Exception $e) 
{ 
echo $e->getMessage(); 


} 
2 


程序 运行 如 图 14-5 所 示 。 


加 :calho:eyeza=ple_14-6 x 
企 © | D localhost 


150212101 方 波 材料 2015 高 等 数学 92 
150412312 李 静 文法 2015 英语 47 


150313223 于 文 华 会 计 2015 社会 学 67 
150112224 董 海川 自动 化 2015 哲学 58 
140213023 钱 文 刚 金融 2014 西方 经 济 学 67 





14-5 ”使 用 fetch() 方 法 获取 结果 集 数据 
14.4.2 ”fetchAll() 方 法 
fetchAll0 方 法 可 以 获取 结果 集 的 全 部 行 ， 它 的 返回 值 是 一 个 包含 结果 集中 所 有 数据 的 
二 维 数组 。 其 语法 格式 如 下 : 
array PDOStatement::fetchAll (int fetch style,int column index) 
fetchAll0 方 法 的 参数 说 明 如 表 14-9 所 示 。 
表 14-9 ”fetchAll() 的 参数 说 明 























fetch_style 可 选 。 规 定 结果 集 的 返回 方式 ， 可 选 值 见 表 14-8 
column_index 可 选 。 规 定 字段 的 索引 值 
【实例 14-7】 使 用 fetchAl10 方 法 获取 结果 集 的 全 部 数据 。 
<?php 


header ("Content-Type:text/html;charset=gb2312"); 
include once ("pdo_ connect.php"); 
$query="select * from Score "7 


.BAaN. 
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tryt{ 
$result=$pdo->prepare ($query); 
$result->execute (); 
$r=$result->fetchAll (PDO: :FETCH_ASSOC); 
for ($i=0;$i<count ($r) ;$i++) 
{ 
Seho Seisil lh 
echo $e[ISi] "zm sx 
Geho soleil bl 
Geho RE [Si "ke "Fe 
Scho Seloal I" ed br/ 
} 
}catch (Exception $e) 
{ 
echo $e->getMessage(); 


} 
ys 


[对 提示 : ”fetchAll0 方 法 获取 的 是 结果 集 的 全 部 数据 ， 其 结果 为 二 维 效 组 ， 其 中 第 一 
维 为 行 号 ， 从 0 开始; 第 二 维 为 字段 名 称 。 
14.4.3 ”fetchColumn() 方 法 
fetchColumn() 方 法 获取 结果 集中 下 一 行 的 指定 列 的 值 ， 其 语法 格式 如 下 : 
string PDOStatement::fetchColumn (int column number) 
fetchColumn() 方 法 参数 说 明 如 表 14-10 所 示 。 
表 14-10 ”fetchClomn() 的 参数 说 明 





忽略 ， 则 从 第 一 列 开始 取 值 


【实例 14-8】 使 用 fetchColumn() 获 取 结 果 集 中 下 一 行 的 一 列 数据 。 


<?php 
header ("Content-Type:text/html;charset=gb2312"); 
include once ("pdo_connect .php"); 
$query="select * from ScCore "ps 
$result=$pdo->prepare ($query); 
$result->execute () 7 
echo $result->fetchCcolumn (0) ; // 获 取 第 一 行 第 一 列 的 值 
区 
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14.5 ”PDO 错误 处 理 
14.5.1 errorCode() 方 法 


errorCode() 方 法 用 于 捕获 在 操作 数据 库 句 柄 时 所 发 生 的 错误 ， 其 中 的 错误 代码 被 称 为 
SQLSTATE 代码 。errorCode() 方 法 的 语法 格式 如 下 : 


int PDOStatement : :errorCode (void) 


erorCode() 方 法 返回 一 个 SQLSTATE，SQLSTATE 是 由 数字 和 字母 组 成 的 一 个 长 度 为 
5 的 字符 串 。 
【实例 14-9】 显 示 errorCode 错误 代码 。 
<?php 
header ("Content-Type:text/html;charset=gb2312"); 
include_once ("pdo_connect .php"); // 通 过 PDo 连接 数据 库 
try 
{ 





$query="select * from s_score"; 
$result=$pdo->query ($query); 
echo "erroCode:",$pdo->errorCode (); // 显 示 错 误 代码 
}catch (PDOException $e) 

{ 
echo "错误 : ", $e->getMessage(); 

1 

?> 


在 SQL 语句 里 查询 的 表 名 s_score 是 不 存在 的 ， 显 示 的 错误 代码 如 图 14-6 所 示 。 


国 1ocalhost/erasp1e_11-s x We 
€ 3 © | localhost/exam 


erroCode:42502 





图 14-6 ”通过 errorCode() 方 法 捕获 错误 代码 
14.5.2 ”errorlnfo() 方 法 


errorInfo() 方 法 用 于 获取 操作 数据 库 句柄 时 所 发 生 的 错误 信息 ， 其 语法 格式 为 : 
array PDOStatement::errorInfo (void) 


errorInfo() 返 回 值 为 一 个 数组 ， 它 包含 了 相关 的 错误 信息 。 
【实例 14-10】 显 示 errorInfo 错误 信息 。 
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<?php 
header ("Content-Type:text/html;charset=gb2312"); 
include_once ("pdo_connect .php"); // 通 过 PDO 连接 数据 库 
try 
{ 
$query="select * from s_score"; 
$result=$pdo->query ($query); 
print_r($pdo->errorInfo()); // 显 示 错 误 信息 
}catch (PDOException $e) 
{ 
echo "错误 : ", $e->getMessage (); 
1 
区 


在 SQL 语句 里 查询 的 表 名 s_score 是 不 存在 的 ， 显 示 的 错误 信息 如 图 14-7 所 示 。 





Array ( [0] =》42S02 0] => 1146 [2] => Table 


’ student. s_score’” doesn’ t exist ) 





14-7 ”通过 errorlnfo() 方 法 捕获 错误 信息 


14.6 ”PDO 捕获 SQL 语句 中 的 错误 


在 PDO 中 捕获 SQL 语句 的 错误 可 以 使 用 PDO 函数 setAttribute() 来 实现 ， 其 语法 格式 
如 下 : 


bool PDO::setAttribute ( int attribute , mixed value ) 


函数 功能 : 设置 数据 库 句柄 的 属性 。 
参数 的 说 明 如 表 14-11 所 示 。 
表 14-11 函数 setAttribute() 的 参数 说 明 


参 数 含义 

规定 数据 库 句柄 属性 。 常 用 的 属性 有 

PDO::ATTR_CASE: 强制 列 名 为 指定 的 大 小 写 ; 

attribute PDO::ATTR_ERRMODE: 错误 报告 ; 
PDO::ATTR_ORACLE_NULLS: 转换 NULL 和 空 字 符 串 ; 
PDO::ATTR_TIMEOUT: ”指定 超时 的 秒 数 

规定 属性 的 值 。 在 这 里 显示 错误 报告 的 值 有 三 个 
PDO::ERRMODE_SILENT: 仅 设 置 错误 代码 ， 默 认 值 ; 
PDO::ERRMODE_WARNING: 警告 模式 ， 引 发 E WARNING 错误 ; 
PDO::ERRMODE _ EXCEPTION: 异常 模式 ， 抛 出 exceptions 异常 











value 
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14.6.1 使 用 默认 模式 PDO::ERRMODE _SILENT 





在 默认 模式 中 ， 设 置 PDOStatement 对 象 的 errorCode 属性 ， 但 不 进行 其 他 任何 操作 。 
【实例 14-11】 使 用 默认 模式 设置 errorCode 属性 ， 检 测 代码 中 的 错误 。 


<?php 
header ("Content-Type:text/html;charset=gb2312"); 
include_once ("pdo_connect .php") ; // 通 过 PDO 连接 数据 库 
$s_xh="13031201"; 
$s_xm=" 赵 文 华 "; 
$5.bj=" 广 告 2013"; 
$s_kc=" 大 学 语文 "; 
$s_cj="78"; 
$query="insert into score (xh,xm,bj,kc,cj) 
Waluest" os Xl Vo zm ob oe cl 
$result=$pdo->prepare ($query); 
$result->execute(); 
$code=$result->errorCode () ;  ”// 接 收 错误 代码 
if (empty ($code)) 
echo "添加 记录 成 功 ! "; 
else // 显 示 错 误 信 息 
echo "错误 : ",var_dump ($result->errorInfo()); 
汉学 


由 于 字段 oj 的 值 为 整 型 ， 所 以 语句 $s_cj="78" 将 $s_cj 的 值 设置 为 字符 串 型 是 错误 的 ， 
导致 输出 结果 如 图 14-8 所 示 。 








国 1ocalhost/ezasple_14-i0 x 
€ © 日 localhost/example_14-1 


错误 ，array(3) { [0]=> string(5) “42S22” [1]=> 
int (1054) [2]=> string(37) “Unknom column 


"scj’ in field list’”} 





图 14-8 ”在 默认 模式 下 捕获 SQL 中 的 错误 


14.6.2 ”使 用 警告 模式 PDO::ERRMODE_WARNING 


警告 模式 会 产生 一 个 警告 ， 并 设置 errorCode 属性 。 在 警告 模式 下 ， 程 序 会 继续 按照 
其 方式 运行 下 去 ， 除 非 要 检查 其 错误 代码 。 
【实例 14-12】 使 用 警告 模式 设置 errorCode 属性 ， 检 测 代码 中 的 错误 。 
<?php 
header ("Content-Type:text/html;charset=gb2312"); 


include_once ("pdo_connect .php"); // 通 过 PDo 连接 数据 库 
try 
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{ 
// 设 置 警告 模式 
$pdo->setAttribute (PDO: :ATTR_ERRMODE,PDO: :ERRMODE WARNING); 
$query="select * from s_score"™; 
$result=$pdo->prepare ($query); 
$result->execute () 7 
while($r=$result->fetch (PDO: :FETCH _OBJ) ) 
{ 

echo, SE->Kh,™ "> 

echo $r->xm," "7 

echo $r->bj," "7 

echo $r->kc," "7 

echo $r->cj,"<br/> "7 
} 
}catch (PDOException $e) 
{ 

echo "错误 : ", $e->getMessage(); 

} 

?2> 


程序 里 执行 的 SQL 语句 中 ， 查 询 的 表 s_score 不 存在 ， 因 而 程序 运行 后 会 出 现 警告 ， 
如 图 14-9 所 示 。 


at/axasple_14-31 X 


>、 © 口 localhost 


Warning: PDOStatement : :execute() : SQLSTATE[42S02] : 
Base table or view not found: 1146 Table 


“student. s_score’ doesn + exist in 
C:\xampp\htdocs\example_14-11. php on line 10 





图 14-9 在 警告 模式 下 捕获 SQL 中 的 错误 信息 


14.6.3 ”使 用 异常 模式 PDO::ERRMODE_EXCEPTION 


异常 模式 会 创建 一 个 PDOException， 并 设置 errorCode 属性 。 
【实例 14-13】 使 用 异常 模式 设置 errorCode 属性 ， 检 测 代码 中 的 错误 。 


<?php 
header ("Content-Type:text/html;charset=gb2312"); 
include_once ("pdo_connect .php"); // 通 过 PDo 连接 数据 库 
try 


{ 

// 设 置 异常 模式 

$pdo->setAttribute (PDO: :ATTR_ERRMODE, PDO: :ERRMODE EXCEPTION); 
$query="select * from SSCOFG 

$result=$pdo->prepare ($query); 

$result->execute(); 

while (Sr=Sresult->fetch (PDO: :FETCH_OBJ)) 
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echo S$r->xh," ™ 
echo S$r->xm," "2 
echo $r->bj," " 
echo $r->kc,™ "7 
echo $r->cj,"<br/> "7 
} 
}catch (PDOException $e) 
echo "错误 : ", $e->getMessage () ; 
区 


在 设置 为 异常 模式 后 ， 执 行 错误 的 SQL 语句 返回 的 结果 如 图 14-10 所 示 。 


Ey 





错误 ，SQLSTATE [42S02] : Base table or view not 
found: 1146 Table ’ student.s_score’ doesn' t exist 


14-10 ”异常 模式 捕获 的 SQL 中 出 现 的 错误 


14.7 PDO 事务 处 理 


在 PDO 中 也 可 以 进行 事务 的 处 理 ， 包 括 : 开启 事务 、 提 交 事务 以 及 回 深 事 务 。 

1. 开启 事务 

开启 事务 是 通过 beginTransaction() 方 法 来 实现 的 。 该 方法 将 关闭 自动 提交 (autocommit) 
模式 ， 直 到 事务 提交 或 者 事务 回 滚 以 后 才 恢 复 。 

2. 事务 提交 

事务 提交 是 通过 commit( 方 法 来 完成 的 。 该 方法 若 提交 成 功 ， 则 返回 TRUE， 和 否则 返 
回 FALSE。 

3. 事务 回 滚 

事务 回 滚 是 通过 rollback() 方 法 来 完成 的 。 

【实例 14-14】 事 务 的 开启 、 提 交 以 及 回 滚 。 


<?php 
header ("Content-Type:text/html;charset=gb2312"); 
include_once ("pdo_connect .php"); // 通 过 PDO 连接 数据 库 
try 
{ 








$pdo->beginTransaction();  // 开 启事 务 
$sql="update score set bj=' 通 信 2015' where xh='150212101'"; 
$result=$pdo->prepare ($sql1); 
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$result->execute (); 
$pdo->commit (); // 提 交 事务 
}catch (PDOException $e) 
| 
echo "错误 : ", $e->getMessage(); 
$pdo->rollback (); // 回 滚 事 务 


14.8 综合 实 训 案 例 


本 节 主 要 介绍 利用 PDO 设计 用 户 登录 界面 的 方法 和 步骤 。 

1. 分 析 

假定 有 数据 库 bookmanage， 其 中 包含 数据 表 user， 表 结构 如 表 14-12 所 示 。 
表 14-12 ”user 表 结构 





Varchar 





Varchar 


创建 登录 网 页 login.html， 在 文件 中 创建 form 表单 ， 添 加 两 个 文本 框 控件 ， 名 称 分 别 
为 login_name、login_password。 文 件 运行 结果 如 图 14-11 所 示 。 





14-11 ”登录 界面 


用 户 在 页 面 上 依次 输入 用 户 名 和 登录 密码 ， 单 击 “ 提 交 ” 按 钮 后 ， 系 统 调用 PHP 程序 
给 证 提交 的 用 户 名 和 用 户 密码 是 否 正确 ， 如 正确 ， 则 显示 “登录 成 功 ! ”， 否 则 显示 “用 
户 名 或 密码 错误 ! 登录 失败 ”。 


2. 程序 代码 
login html 文件 代码 如 下 : 


<html> 

<head> 

<meta http-equiv="Content-Language" content="zh-cn"> 

<meta http-equiv="Content-Type" content="text/html; charset=gb2312"> 
<title> 登 录 页 面 </title> 
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</head> 

<body> 

<div align="center"> 

<form action ="check login.php" method=post> 

<p align="center"><font size="5"> 欢 迎 登 录 </font><br/> 

用 户 名 <input type="text" name="login name" size="30"><br/> 

密码 <input type="password" name="login password" size="30"><br/> 
<input type="submit" value=" 提 交 " name="Bl">&gnbsp;&nbsp; 

<input type="reset" value=" 重 置 " name="B2" 


</form> 

</div> 

</body> 

</html> 

创建 PHP 程序 文件 pdo_connect.php， 通 过 PDO 连接 MySQL 服务 器 。 程 序 代码 如 下 : 

<?php 
$db_name="bookmanage"; // 数 据 库 名 称 
$user="root"; // 连 接 数 据 库 的 用 户 名 
$password=""; // 连 接 数 据 库 的 密码 
$host="localhost"; // 数 据 库 服 务 器 地 址 
$dsn="mysql:host=$host;dbname=$db_name"; // 数 据 源 名 称 
tryt{ 


$pdo=new PDO($dsn, $user,$password); // 实 例 化 对 象 
$pdo->query ("set names gb2312"); 

}catch (Exception $e) // 捕 捉 错 误 信 息 

{ 
echo $e->getMessage(); 


, 
?> 


创建 PHP 程序 文件 check_login.php， 采 集 login.html 页 面 的 用 户 名 及 登录 密码 数据 ， 
通过 PDO 连接 MySQL 数据 库 ， 打 开 数据 表 user， 查 询 用 户 名 和 登录 密码 是 否 正确 。 程 序 
代码 如 下 : 


<?php 
include_once ("pdo_connect.php"); // 包 含 pdo_connect.php 文件 
header ("Content-Type:text/html;charset=gb2312"); 
$user_name=$_POST["login_name"]; // 采 集 登 录用 户 名 
$user_password=$_POST["login_password"]; // 采 集 用 户 登 录 密 码 
// 判 断 用 户 名 或 用 户 密码 是 否 为 空 
if(empty ($user name) || empty ($user password) ) 

ii 





echo "用 户 密码 不 得 为 空 "; 
} 
els 
// 在 user 表 中 查询 是 否 存在 该 用 户 名 和 登录 密码 
$sql="select * from user Where name=:user name and 
password=:user password "7 
try{ 
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$result=$pdo->prepare ($sql); 
$result->execute (array(' :user name'=>$user name, 
':user password'=>$user password)); 
if($r=$result->fetch (PDO: :FETCH_ASSOC)) 
. 
echo "用 户 登录 成 功 ! "; 
} 
SLSe 
‘ 
echo "用 户 名 或 密码 不 正确 ! 登录 失败 ! "; 
} 
}catch (Exception $e) 
. 
echo $e->getMessage(); 
} 


本 章 小 结 


本 章 详 细 介 绍 了 PDO 的 特点 ， 使 用 PDO 连接 MySQL 数据 库 的 方法 ， 在 PDO 中 实现 
SQL 语句 操作 数据 表 的 方法 及 步 又， 在 PDO 中 捕捉 错误 的 方法 ， 以 及 PDO 中 有 关 事 务 处 
理 的 方法 。 


习 题 


1. 通过 PDO 连接 MySQL 服务 器 ， 向 score 表 中 添加 一 条 记录 : 学 号 为 150311215， 
姓名 为 “李建军 ”， 班 级 为 “机 械 2015” ， 课 程 为 “机 械 检测 ”， 成 绩 为 84。 

2. 通过 query() 方 法 查询 并 显示 score 表 中 班级 为 “会 计 2015” 的 多 集 记录 信息 。 

3. 通过 预 处 理 语句 prepare() 和 execute()， 查 询 score 表 中 成 绩 在 70 一 90 之 间 的 全 部 记 
录 信 息 。 
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